继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

JavaScript之全选/反选/取消,for循环闭包

holdtom
关注TA
已关注
手记 1703
粉丝 240
获赞 991


需求:table中要求点击红色单元格和点击checkbox的效果一样,最后一行点击就是全选、反选、取消选择的效果。

JavaScript之全选/反选/取消,for循环闭包

<!DOCTYPE html>

<html>

<head>

    <meta charset="UTF-8">

    <title>Title</title>

    <style>

        table{

            width: 400px;

            height: 15px;

            background-color: palegreen;

            text-align: center;

        }

        .check{

            width: 20%;

            background-color: indianred;

        }

        input{

            display: inline-block;

            vertical-align:middle;

        }

        div{

            display: inline-block;

            width: 400px;

        }

        div input{

            display: inline-block;

            width: 20%;

        }

        .select{

            background-color: bisque;

        }

    </style>

</head>

<body>

<table border="1" cellpadding="0" cellspacing="0">

    <tr>

        <td class="check"><input class="inputcheck" type="checkbox"></td>

        <td>富贵竹</td>

        <td>绿萝</td>

    </tr>

    <tr>

        <td class="check"><input class="inputcheck" type="checkbox"></td>

        <td>栀子花</td>

        <td>月季</td>

    </tr>

    <tr>

        <td class="check"><input class="inputcheck" type="checkbox"></td>

        <td>金银花</td>

        <td>菊花</td>

    </tr>

    <tr>

        <td class="check check4"><input class="inputcheck" type="checkbox"></td>

        <td>玫瑰</td>

        <td>百合</td>

    </tr>

    <tr class="select">

        <td><input class="selectall" type="button" value="全选"> </td>

        <td><input class="reserve" type="button" value="反选"> </td>

        <td><input class="cancel" type="button" value="取消"> </td>

    </tr>

</table>

<script>

    var ele= document.getElementsByTagName("input");

    var check= document.getElementsByClassName("check");

    var inputcheck= document.getElementsByClassName("inputcheck");

    var all = document.getElementsByClassName("selectall")[0];

    var reserve = document.getElementsByClassName("reserve")[0];

    var cancel = document.getElementsByClassName("cancel")[0];

    //for循环闭包

    for(var i=0;i<check.length;i++){

        var td =  check[i];

        td.onclick = function () {

            var td =  check[i];

            return function () {

                var input = td.getElementsByTagName("input")[0];

                if(input.checked){

                    input.checked = false;

                }else {

                     input.checked = true;

                }

            }

        }(i)

    }

    //for循环闭包

    for(var i=0;i<inputcheck.length;i++){

        var input =  inputcheck[i];

        input.onclick = function () {

            var input =  inputcheck[i];

            return function () {

                if(input.checked){

                    input.checked = false;

                }else {

                     input.checked = true;

                }

            }

        }(i)

    }

    //全选

    all.onclick=function () {

        for(var i=0;i<ele.length;i++){

            ele[i].checked=true;

        }

    }

    //反选

    reserve.onclick=function () {

        for(var i=0;i<ele.length;i++){

            if(ele[i].checked){

                ele[i].checked=false;

            }

            else {

                ele[i].checked=true;

            }

        }

    }

    //取消

    cancel.onclick =function () {

        for(var i=0;i<ele.length;i++){

            ele[i].checked=false;

        }

    }

</script>

</body>

</html>

©著作权归作者所有:来自51CTO博客作者易水寒月的原创作品,如需转载,请注明出处,否则将追究法律责任


打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP