--- layout: post title: "选择框的全选联动" date: 2017-09-19 22:00:37+0800 thumb: IMG_PATH/js.svg category: tech tags: ["Checkbox", "JavaScript"] --- 最近工作更忙了,博客已经十来天没更新了,今晚有空闲,懒得扒太麻烦的话题,聊一下简单的 JS 效果,这篇主要说的是选择框的全选联动。 我这里所说的全选联动是: ```html ``` 以上六个选择框,且将最后一个叫全选选择框,其余叫其余选择框。 1. 选中全选选择框,其余选择框均被选中;反选全选选择框,其余选择框均未选。 2. 其余选择框都选中时,全选选择框也被选中;其余选择框只要有一项未被选中,全选选择框未选中。 这个 CSS 一般没法实现,但 CSS 的奇淫技巧,也不是第一次见识了,或许会有办法?这里还是说下 JS 实现。 第一个很好实现,只要全选选择框触发 change 事件时执行操作即可。 ```js var checkboxes = document.getElementsByClassName('checkbox'); document.getElementById('selectAll').addEventListener('change', function(e) { for (var i = 0; i < checkboxes.length; i++) { checkboxes[i].checked = e.target.checked; } }, false) ``` 第二个无非就是判断多个选择框,如下: ```js for (var i = 0; i < checkboxes.length; i++) { checkboxes[i].addEventListener('change', function(e) { var checked = true; for (var n = 0; n < checkboxes.length; n++) { if (!checkboxes[n].checked) { checked = false; } } document.getElementById('selectAll').checked = checked; }, false) } ``` {% include media.html type="iframe" src="//jsfiddle.net/fooleap/2bbky4gf/1/embedded/result,js,html/" %} 这本是最常见的功能,购物车、后台管理等常用,本篇有些凑字数的感觉。 **本文历史** * 2017 年 09 月 19 日 完成初稿