有个比较奇怪的问题,checkbox的checked="cheecked"属性已添加,但是前边却没有后打钩
如图所示,第一个已是checked="checked"
======================================
上边是一个全选按钮,我试图点这个复选框来实现下边复选框的全选/全不选
但是效果不佳
效果呈现为:第一次点这个复选框,下边所有的都被勾选. 再点这个复选框,下边所有的都被取消勾选. 之后再点这个复选框无论多少次,只有属性的变化没有勾选的显示
代码如下:
if(document.getElementById("checkAll").checked){
$("input[name='jinjian']").attr("checked","checked");
}else{
$("input[name='jinjian']").prop("checked",false).removeAttr("checked");
}
$("input[name='jinjian']").attr("checked",document.getElementById("checkAll").checked);
$("input[name='jinjian']").attr("checked",$(this).attr("checked"));
if($("#checkAll").prop("checked") == true){
$("input[name='jinjian']").prop("checked",true);
}else{
$("input[name='jinjian']").prop("checked",false);
}
<!doctype html>
<html>
<head>
<meta charset="gb2312">
<title>无标题文档</title>
<script type="text/javascript" src="jquery1.7.js"></script>
<script type="text/javascript">
$(document).ready(function(e) {
$("#quanxuan").click(function(e) {
if ($(this).attr("checked")=="checked"){
$("input[name='jinjian']").attr("checked",true)
}
else{
$("input[name='jinjian']").removeAttr("checked")
}
});
});
</script>
</head>
<body>
<table width="400" border="1" align="center" id="table1">
<tr>
<td><input type="checkbox" name="quanxuan" id="quanxuan"></td>
<td>a</td>
</tr>
<tr>
<td><input type="checkbox" name="jinjian"></td>
<td>1</td>
</tr>
<tr>
<td><input type="checkbox" name="jinjian"></td>
<td>2</td>
</tr>
<tr>
<td><input type="checkbox" name="jinjian" ></td>
<td>3</td>
</tr>
<tr>
<td><input type="checkbox" name="jinjian" ></td>
<td>4</td>
</tr>
<tr>
<td><input type="checkbox" name="jinjian"></td>
<td>5</td>
</tr>
<tr>
<td><input type="checkbox" name="jinjian" ></td>
<td>6</td>
</tr>
<tr>
<td><input type="checkbox" name="jinjian"></td>
<td>7</td>
</tr>
</table>
</body>
</html>
.prop("checked",false) 试着把false改为""试试,如下:
.prop("checked","")
[解决办法]
if ($(this).attr("checked")=="checked") 你这里写的有错误啊 和环境没关吧
if ($(this).attr("checked"))这样写