全選和不選的實現
阿新 • • 發佈:2018-11-30
<style>
* {
padding: 0;
margin: 0;
}
.wrap {
width: 300px;
margin: 100px auto 0;
}
table {
border-collapse: collapse;
border-spacing: 0;
border: 1px solid #c0c0c0;
width: 300px;
}
th,
td {
border: 1px solid #d0d0d0;
color: #404060;
padding: 10px;
}
th {
background-color: #09c;
font: bold 16px "微軟雅黑";
color: #fff;
}
td {
font: 14px "微軟雅黑";
}
tbody tr {
background-color: #f0f0f0;
}
tbody tr:hover {
cursor: pointer;
background-color: #fafafa;
}
</style>
</head>
<body>
<div class="wrap">
<table>
<thead>
<tr>
<th>
<input type="checkbox" id="j_cbAll"/>
</th>
<th>菜名</th>
<th>飯店</th>
</tr>
</thead>
<tbody id="j_tb">
<tr>
<td>
<input type="checkbox"/>
</td>
<td>紅燒肉</td>
<td>田老師</td>
</tr>
<tr>
<td>
<input type="checkbox"/>
</td>
<td>西紅柿雞蛋</td>
<td>田老師</td>
</tr>
<tr>
<td>
<input type="checkbox"/>
</td>
<td>油炸榴蓮</td>
<td>田老師</td>
</tr>
<tr>
<td>
<input type="checkbox"/>
</td>
<td>清蒸助教</td>
<td>田老師</td>
</tr>
</tbody>
</table>
</div>
<script src="commer.js"></script>
<script>
//獲取全選的這個複選框
var ckAll=ver("j_cbAll");
//獲取tbody中所有的小複選框
var cks=ver("j_tb").getElementsByTagName("input");
//點選全選這個複選框,獲取他當前的狀態,然後設定tbody中所有複選框的狀態
ckAll.onclick=function () {
for(var i=0;i<cks.length;i++){
cks[i].checked=this.checked;
}
};
//獲取tbody中所有的複選框,分別註冊點選事件
for(var i=0;i<cks.length;i++){
cks[i].onclick=function () {
var flag=true;//預設的都被選中了
//判斷是否所有的複選框都選中了
for(var j=0;j<cks.length;j++){
if(!cks[j].checked){
flag=false;
break;
}
}
//全選的這個複選框的狀態就說flag這個變數的值
ckAll.checked=flag;
};
}
</script>