美文网首页
两种方法实现全选或全不选

两种方法实现全选或全不选

作者: 码课sir | 来源:发表于2018-07-22 21:47 被阅读0次

方法一:Prop实现

代码如下

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <script type="text/javascript" src='./jquery.js'></script>
</head>
<body>
        用户名: <input type="text" name="username" value='切格瓦拉'> <br>
    爱好: 
        <input type="checkbox" name="hobby[]" value='0'>敲代码
        <input type="checkbox" name="hobby[]" value='1'>删库
        <input type="checkbox" name="hobby[]" value='2'>跑路
        <input type="checkbox" name="hobby[]" value='3'>打篮球
        <input type="checkbox" name="hobby[]" value='4'>打台球
        <input type="checkbox" name="hobby[]" value='5'>打麻将  
        <hr>

        <button id='selectAll'>全选</button>
        <button id='cancel'>全不选</button>
        <button id='fanxuan'>反选</button>
</body>
<script type="text/javascript">
    $("input[name='username']").prop('disabled',true); //不可用
    //$("input[name='username']").prop('disabled',false); //可用
    console.log( $("input[name='username']").prop('disabled') ); // true

    $("#selectAll").click(function(){
        //获取到所有的复选框,都进行批量设置为选中
        $("input[name='hobby[]']").prop('checked',true);
    });

    $("#cancel").click(function(){
        //获取到所有的复选框,都进行批量设置为都不选中
        $("input[name='hobby[]']").prop('checked',false);
    });

    $("#fanxuan").click(function(){
        //获取到所有的复选框,循环获取到每个dom对象进行选中取反操作
        var checkboxs = $("input[name='hobby[]']");
        for(var i=0,length = checkboxs.length; i<length; i++){
            //DOM方式:通过下标获取到dom对象
            //checkboxs[i].checked = !checkboxs[i].checked;
            //jquery方式:
            $(checkboxs[i]).prop('checked',!$(checkboxs[i]).prop('checked'));
        }
    });
</script>
</html>

方法二:扩展机制实现

代码如下

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <link rel="stylesheet" type="text/css" href="style.css">
</head>
<body>
    爱好: 
        <input type="checkbox" name="hobby[]" value='0'>敲代码
        <input type="checkbox" name="hobby[]" value='1'>删库
        <input type="checkbox" name="hobby[]" value='2'>跑路
        <input type="checkbox" name="hobby[]" value='3'>打篮球
        <input type="checkbox" name="hobby[]" value='4'>打台球
        <input type="checkbox" name="hobby[]" value='5'>打麻将  
        <hr>
        <button id='selectAll'>全选</button>
        <button id='cancel'>全不选</button>
        <button id='fanxuan'>反选</button>
</body>
<script type="text/javascript" src='./jquery.js'></script>
<script type="text/javascript" src="checkAll.js"></script>
<script type="text/javascript">

    //全选
    $("#selectAll").click(function(){
        $("input[name='hobby[]']").checkedAll();
    });

    //全不选
    $("#cancel").click(function(){
        $("input[name='hobby[]']").cancelAll();
    });

    //反选
    $("#fanxuan").click(function(){
        $("input[name='hobby[]']").fanxuan();
    });
    
</script>
</html>

建议:
a、外部的引入css文件放在head中,先渲染页面,
b、把外部引入的js文件定义在body的下面,防止页面阻塞。

相关文章

网友评论

      本文标题:两种方法实现全选或全不选

      本文链接:https://www.haomeiwen.com/subject/ncmrmftx.html