题解 | #全选#
全选
https://www.nowcoder.com/practice/84b89f326e3c4e96bacb63296e84623a
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> </head> <style> ul { list-style: none; } </style> <body> <ul> <li>全选<input type='checkbox' id='all'></li> <li>Java<input type='checkbox' class='item'></li> <li>javaScript<input type='checkbox' class='item'></li> <li>C++<input type='checkbox' class='item'></li> <li>python<input type='checkbox' class='item'></li> <li>.net<input type='checkbox' class='item'></li> </ul> <script> // 补全代码 // 1、获取元素 var all = document.getElementById("all") var options = Array.from(document.getElementsByClassName("item")) // 2、实现全选按钮 all.onchange=function(){ options.forEach(item =>{ item.checked=all.checked; }) } // 3、实现其他元素 options.forEach(item =>{ // 监听每一个复选框 item.onchange=function(){ // 每一个复选框的改变事件 var isPlay = true; options.forEach(value =>{ // 每当有一个复选框发生改变都要循环一次数组 if(value.checked===false) {isPlay=false; }// 如果有一个复选框的值为false那么就不是全选 }) all.checked=isPlay } }) </script> </body> </html>