使用原生js和jQuery实现表格的隔行变色

原生js实现表格隔行变色:利用原生js操作DOM元素
HTML:


<html>
<head>
<title>1. 使用节点树方式实现表格偶数行变色title>
<meta charset="utf-8" />
<link rel="stylesheet" href="css/3.css" />

<script src="./js/jquery-3.1.0.min.js">script>
<style>.blue {background-color: #ccccff;}style>
head>
<body>
    <table id="data">
        <thead>
            <tr>
                <th>姓名th>
                <th>工资th>
                <th>入职时间th>
                <th>操作th>
            tr>
        thead>
        <tbody>
            <tr>
                <td>Tomtd>
                <td>$3500td>
                <td>2010-10-25td>
                <td><a href="javascript:void(0)" onclick="fun(this)">删除a>td>
            tr>
            <tr>
                <td>Marytd>
                <td>$3400td>
                <td>2010-12-1td>
                <td><a href="javascript:void(0)" onclick="fun(this)">删除a>td>
            tr>
            <tr>
                <td>Kingtd>
                <td>$5900td>
                <td>2009-08-17td>
                <td><a href="javascript:void(0)"  onclick="fun(this)">删除a>td>
            tr>
            <tr>
                <td>Scotttd>
                <td>$3800td>
                <td>2012-11-17td>
                <td><a href="javascript:void(0)"  onclick="fun(this)">删除a>td>
            tr>
            <tr>
                <td>Smithtd>
                <td>$3100td>
                <td>2014-01-27td>
                <td><a href="javascript:void(0)"  onclick="fun(this)">删除a>td>
            tr>
            <tr>
                <td>Allentd>
                <td>$3700td>
                <td>2011-12-05td>
                <td><a href="javascript:void(0)"  onclick="fun(this)">删除a>td>
            tr>
        tbody>
    table>
body>
html>

CSS样式:

#data {
    width: 600px;
}

#data, td, th {
    border-collapse: collapse;
    border: 1px solid #aaaaaa;
}

th, td {
    height: 28px;
}

#data thead {
    background-color: #333399;
    color: #ffffff;
}

原生js:

<script type="text/javascript">
    //根据id号查找到当前的表格
    var table=document.getElementById("data");
    //因为隔行变色不需要头部变色,所以在表格的下面又找到表格的tbody,因为一个表格可以有多个tbody所以要给它添加下标,找到第一个tbody。
    var tbody=table.getElementsByTagName("tbody")[0];
    //再找到tbody里面所有的tr标签
    var trs=tbody.getElementsByTagName("tr");
    //使用for循环遍历所有的tr
    for(var i=0;i//判断当前的下标是奇数还是偶数,实现隔行变色
        if(i%2==0){
            trs[i].className="blue";
        }else{
            trs[i].style.backgroundColor="red";
        }
    }
script>

利用jQuery实现隔行变色就要简单很多了(使用jQuery时要引入jQuery文件哦!):

<script type="text/javascript">
    $("#data>tbody tr:even").css("background-color","red");
    $("#data>tbody tr:odd").css("background-color","blue");
script>

这就是使用原生js和jQuery库之间的区别,两行代码就可以搞定了,但是建议向我这样的小白,还是多用原生js写写,练一练,因为jQuery的底层就是原生js写的,原生的写的很溜了,那么jQuery也就简单了。

你可能感兴趣的:(javascript,jquery)