雖然現在有很多框架可以輕鬆的實現斑馬線效果,而且兼容性也很不錯,例如bootstrap,但是不可否認的是使用JavaScript實現的是兼容性最強的(瀏覽器不支援或禁止JavaScript腳本除外),所以今天使用原生JS實作了一個斑馬線效果的表格,大家可以簡單看一下,如果有需要可以留做腳本累積。本文主要和大家介紹了JavaScript實現的斑馬線表格效果,透過javascript針對table表格的遍歷與運算實現隔行變色功能,非常簡單實用,需要的朋友可以參考下,希望能幫助到大家。
html表格部分:
<table> <thead> <tr> <th>Date</th> <th>City</th> <th>Venue</th> </tr> </thead> <tbody> <tr> <td>2017-06-25</td> <td> <abbr title="BeiJing">BJ</abbr> </td> <td>Ballroom</td> </tr> <tr> <td>2017-08-02</td> <td> <abbr title="ShangHai">SH</abbr> </td> <td>Yoyoyo</td> </tr> <tr> <td>2017-11-30</td> <td> <abbr title="HangZhou">HZ</abbr> </td> <td>NOW~</td> </tr> <tr> <td>2017-11-30</td> <td> <abbr title="HangZhou">HZ</abbr> </td> <td>NOW~</td> </tr> <tr> <td>2017-11-30</td> <td> <abbr title="ShiJiaZhuang">SJZ</abbr> </td> <td>NOW~</td> </tr> </tbody> </table>
script.js
function addClass(element, value) {//element:需要添加新样式的元素,value:新的样式 if (!element.className) { element.className = value; } else { newClassName = element.className; newClassName += " "; newClassName += value; element.className = newClassName; } } function stripeTable(){ if(!document.getElementsByTagName("table")) return false; /*获取table*/ var table = document.getElementsByTagName("table"); /*遍历 为所有表格添加*/ for(var i=0;i<table.length;i++){ /*判断是否为奇数行 * 将第一行设置成true * */ var odd = true; var tr = table[i].getElementsByTagName("tr"); /*遍历表格中的每一行*/ for(var j=0;j<tr.length;j++){ if(odd){ addClass(tr[j],"stripe"); /*将下一行设置称false*/ odd = false; }else{ /*将下一行设置称true*/ odd = true; } } } }
css部分:
* { margin: 0; padding: 0; } .stripe{ background-color: #eee; }
完整index.html程式碼如下:
javascript斑马线表格 <table> <thead> <tr> <th>Date</th> <th>City</th> <th>Venue</th> </tr> </thead> <tbody> <tr> <td>2017-06-25</td> <td> <abbr title="BeiJing">BJ</abbr> </td> <td>Ballroom</td> </tr> <tr> <td>2017-08-02</td> <td> <abbr title="ShangHai">SH</abbr> </td> <td>Yoyoyo</td> </tr> <tr> <td>2017-11-30</td> <td> <abbr title="HangZhou">HZ</abbr> </td> <td>NOW~</td> </tr> <tr> <td>2017-11-30</td> <td> <abbr title="HangZhou">HZ</abbr> </td> <td>NOW~</td> </tr> <tr> <td>2017-11-30</td> <td> <abbr title="ShiJiaZhuang">SJZ</abbr> </td> <td>NOW~</td> </tr> </tbody> </table> <script> stripeTable(); </script>
相關推薦:
以上是JavaScript實作斑馬線表格範例分享的詳細內容。更多資訊請關注PHP中文網其他相關文章!