学习DOM的第二天 练习案例:表格隔行变色 表格的全选与取消全选

1.表格的隔行变色

鼠标划入与划出。   划入变色className='bg',划出className=' ' ;

 

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        table{
            border-collapse: collapse;
        }
        thead tr td{
            background-color: cadetblue;
            border: 1px solid rgb(177, 70, 70);
           
        }
        tbody tr td{
            border: 1px solid rgb(177, 70, 70);
        }
        .bg{
            background-color: brown;
        }
    </style>
</head>
<body>
    
    <table>
        <thead>
            <tr>
                <td>代码</td>
                <td>名称</td>
                <td>公布净值</td>
                <td>累计净值</td>
                <td>前单位净值</td>
            </tr>
        </thead>
        <tbody>
            <tr>
                <td>0001</td>
                <td>农行定期开放债券</td>
                <td>1.075</td>
                <td>1.079</td>
                <td>1.074</td>
            </tr>
            <tr>
                <td>0002</td>
                <td>广东理财30天债券</td>
                <td>0.903</td>
                <td>3.386</td>
                <td>0.000</td>
            </tr>
            <tr>
                <td>0003</td>
                <td>兴全合宜混合A</td>
                <td>0.860</td>
                <td>0.860</td>
                <td>0.863</td>
            </tr>
            <tr>
                <td>0004</td>
                <td>中银证券债券A</td>
                <td>1.034</td>
                <td>1.088</td>
                <td>1.034</td>
            </tr>
            <tr>
                <td>0005</td>
                <td>光大添天盈月债券B</td>
                <td>0.950</td>
                <td>3.557</td>
                <td>0.000</td>
            </tr>
        </tbody>
    </table>
    <script>
        var trs=document.querySelectorAll('tr');
        for(var i=0;i<trs.length;i++){
            trs[i].onmouseover=function(){
            //    console.log(11);
                this.className='bg';
            }
            trs[i].onmouseout=function(){
                this.className='';
            }
        }
    </script>
</body>
</html>

2.表格的全选与取消全选

分为一个总控制开关和分路开关 。当总开关打开时分路开关全部打开, 一个循环 所有  j_tbs[i].checked=this.checked;        分开关全部打开时总开关亮起,所以每打开一个分开关,遍历判断是否所有的分开关都亮起,如果是就打开总开关。不理解的可以评论区提问哦。

 

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
    div{
        display: flex;
        justify-content: center;
    }
    table{
        border-collapse: collapse;
    }
    thead tr th{
        background-color:darkorange;
        border: 1px solid rgb(177, 70, 70);
       
    }
    tbody tr td{
        border: 1px solid rgb(177, 70, 70);
    }
</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>iPhone8</td>
                    <td>8000</td>
                </tr>
                <tr>
                    <td>
                        <input type="checkbox" />
                    </td>
                    <td>iPhone9</td>
                    <td>10000</td>
                </tr>
                <tr>
                    <td>
                        <input type="checkbox" />
                    </td>
                    <td>iPhone10</td>
                    <td>2000</td>
                </tr>
            </tbody>
        </table>
    </div>

    <script>
        var j_cbAll = document.getElementById('j_cbAll'); //全选按钮
        var j_tbs = document.getElementById('j_tb').getElementsByTagName('input');
        
 
        j_cbAll.onclick = function(){
            for(var i=0;i<j_tbs.length;i++){
                j_tbs[i].checked=this.checked; 
            }
        }
        //下面复选按钮全选中,上面被按
        for(var i=0;i<j_tbs.length;i++){
            j_tbs[i].onclick = function(){
                var flag=true;
                for(var j=0;j<j_tbs.length;j++){
                    if(!j_tbs[j].checked){
                        flag=false;
                        console.log(flag);
                    }
                  
                }
                j_cbAll.checked=flag;
            }
        }
    </script>
</body>
</html>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值