首頁(yè)技術(shù)文章正文

鼠標(biāo)放到表格整行變色效果怎么實(shí)現(xiàn)?

更新時(shí)間:2021-11-08 來(lái)源:黑馬程序員 瀏覽量:

鼠標(biāo)放到表格上整行變色效果怎么實(shí)現(xiàn)?現(xiàn)在有個(gè)黑馬程序員HTML&JS+前端開發(fā)課程的開班表格,如下圖所示:

鼠標(biāo)懸停表格變色

我們需要通過JS實(shí)現(xiàn)鼠標(biāo)放到表格上整行變色,如何實(shí)現(xiàn)這個(gè)功能呢?

表格HTML代碼如下:

<table>
    <thead>
        <tr>
            <th></th>
            <th>班級(jí)類型</th>
            <th>開班時(shí)間</th>
            <th>開班狀態(tài)</th>
        </tr>
    </thead>
    <tbody id="tb">
        <tr>
            <td>
                <input type="checkbox" />
            </td>
            <td>基礎(chǔ)班</td>
            <td>2021-08-31</td>
            <td>報(bào)滿已開</td>
        </tr>
        <tr>
            <td>
                <input type="checkbox" />
            </td>
            <td>基礎(chǔ)班</td>
            <td>2021-09-11</td>
            <td>報(bào)滿已開</td>
        </tr>
        <tr>
            <td>
                <input type="checkbox" />
            </td>
            <td>高手班</td>
            <td>2021-08-05</td>
            <td>報(bào)滿已開</td>
        </tr>
        <tr>
            <td>
                <input type="checkbox" />
            </td>
            <td>高手班</td>
            <td>2021-09-28</td>
            <td>報(bào)滿已開</td>
        </tr>
        <tr>
            <td>
                <input type="checkbox" />
            </td>
            <td>高手班</td>
            <td>2021-11-11</td>
            <td>即將開班</td>
        </tr>
    </tbody>
</table>

功能實(shí)現(xiàn)思路:

1、事件委托,將mouseover事件綁定到tbody上,當(dāng)鼠標(biāo)移動(dòng)到表格上時(shí)觸發(fā)

2、通過target事件對(duì)象找到父級(jí)元素tr,并改變其背景色

3、將mouseout事件綁定到tbody上,鼠標(biāo)移出時(shí)觸發(fā)

下面通過代碼實(shí)現(xiàn):

<!DOCTYPE html><html lang="en"><head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>通過JS使表格懸浮變色|web前端高手班 http://web.itheima.com</title>
    <style>
        table {
            border-collapse: collapse;
            border-spacing: 0;
            border: 1px solid #c0c0c0;
            width: 500px;
        }

        th,
        td {
            border: 1px solid #d0d0d0;
            color: #404060;
            padding: 10px;
            text-align: center;
        }
    </style></head><body>
    <table>
        <thead>
            <tr>
                <th></th>
                <th>班級(jí)類型</th>
                <th>開班時(shí)間</th>
                <th>開班狀態(tài)</th>
            </tr>
        </thead>
        <tbody id="tb">
            <tr>
                <td>
                    <input type="checkbox" />
                </td>
                <td>基礎(chǔ)班</td>
                <td>2021-08-31</td>
                <td>報(bào)滿已開</td>
            </tr>
            <tr>
                <td>
                    <input type="checkbox" />
                </td>
                <td>基礎(chǔ)班</td>
                <td>2021-09-11</td>
                <td>報(bào)滿已開</td>
            </tr>
            <tr>
                <td>
                    <input type="checkbox" />
                </td>
                <td>高手班</td>
                <td>2021-08-05</td>
                <td>報(bào)滿已開</td>
            </tr>
            <tr>
                <td>
                    <input type="checkbox" />
                </td>
                <td>高手班</td>
                <td>2021-09-28</td>
                <td>報(bào)滿已開</td>
            </tr>
            <tr>
                <td>
                    <input type="checkbox" />
                </td>
                <td>高手班</td>
                <td>2021-11-11</td>
                <td>即將開班</td>
            </tr>
        </tbody>
    </table></body><script>
    // 1:需要為所有tr綁定懸浮事件,利用事件委托,只需要給父級(jí)綁定事件即可
    // 2:找到父級(jí)元素,綁定事件
    var tb = document.getElementById('tb');
    tb.onmouseover = function(ev){
        // 3:獲取事件對(duì)象,利用事件對(duì)象獲取target(具體觸發(fā)事件的元素)
        // console.log(ev.target);
        // 注意,觸發(fā)事件的是 td  ,而我們需要讓tr改變背景顏色
        // console.log(ev.target.parentElement)
        ev.target.parentElement.style.background = '#f5f5f5'
    }

    tb.onmouseout = function(ev){
        // 3:獲取事件對(duì)象,利用事件對(duì)象獲取target(具體觸發(fā)事件的元素)
        // console.log(ev.target);
        // 注意,觸發(fā)事件的是 td  ,而我們需要讓tr改變背景顏色
        // console.log(ev.target.parentElement)
        ev.target.parentElement.style.background = ''
    }
    // 改變當(dāng)前行的背景顏色</script></html>


最終效果:

代鼠標(biāo)放到表格上整行變色



猜你喜歡

什么是事件委托? js事件委托怎么實(shí)現(xiàn)?

jQuery的4種常見動(dòng)畫效果

JS綁定事件的方法有哪些?

黑馬程序員HTML&JS+前端課程

分享到:
在線咨詢 我要報(bào)名
和我們?cè)诰€交談!