转行学开发,代码100天——2018-04-21

今天记录一下,JavaScript对表格table的操作应用,包括表格元素的获取,创建,删除等。

一个普通的完整表格包括以下几个部分:table->thead->tbody->tr->td等

1.表格的创建

如下面的一个表格,表头部分:序号-姓名-年龄

其下有三行三列的内容,属于tbody部分

其html结构如下:

<table id="tab" border="3" width="600px" height="40px" >
<thead>
<td>序号</td>
<td>姓名</td>
<td>年龄</td>
</thead> <tbody>
<tr>
<td>1</td>
<td>tom</td>
<td>23</td>
</tr>
<tr>
<td>2</td>
<td>john</td>
<td>33</td>
</tr>
<tr>
<td>3</td>
<td>july</td>
<td>21</td>
</tr> </tbody>
</table>

2.表格元素的获取

比如要想获取上述表格中的年龄为21的单元格内容,用什么方法呢?

最普通的实现思路就是逐步获取table->tbody->tr->td

如下:

getElementsByTagName
    window.onload = function(){

          var oTab = document.getElementById("tab");
alert(oTab.getElementsByTagName('tbody')[0].getElementsByTagName('tr')[2].getElementsByTagName('td')[2].innerHTML);
};

而实际上表格本身包括行row和列column方法

alert(oTab.tBodies[0].rows[2].cells[2].innerHTML);

即获取tBody可以用tBodies

获取行用rows

获取单元格用cells

3.隔行变色

 //隔行变色
for (var i = 0; i < oTab.tBodies[0].rows.length; i++) {
if (i%2) {
oTab.tBodies[0].rows[i].style.background ="";
}else
{
oTab.tBodies[0].rows[i].style.background="#666";
}
}

4.鼠标移入移出表格换色

 //鼠标移入移出变色操作
oTab.tBodies[0].rows[i].onmouseover = function(){
this.style.background="#999";
};
oTab.tBodies[0].rows[i].onmouseout = function(){
this.style.background="";
}

此时如果鼠标滑过表格中某行时,该行颜色变色。

如此其基本功能完成了,但是结合上一步,如果同时要求各行换色,鼠标移动操作变色效果会如何呢?

 //隔行变色
for (var i = 0; i < oTab.tBodies[0].rows.length; i++) {
if (i%2) {
oTab.tBodies[0].rows[i].style.background ="";
}else
{
oTab.tBodies[0].rows[i].style.background="#666";
} //鼠标移入移出变色操作
oTab.tBodies[0].rows[i].onmouseover = function(){
this.style.background="#999";
};
oTab.tBodies[0].rows[i].onmouseout = function(){
this.style.background="";
}
}

鼠标移至第一行,其效果:

但是鼠标移开后, 其颜色均为白色,即代码中设置的空

如此便不是我们预期的效果了。。。

这一问题的处理,其实也很简单,即设置一个变量保存鼠标移动行的颜色,鼠标移开时还原即可。

   //隔行变色
for (var i = 0; i < oTab.tBodies[0].rows.length; i++) {
var oOldColor = null; //新建一个保存当前行颜色的变量 if (i%2) {
oTab.tBodies[0].rows[i].style.background ="";
}else
{
oTab.tBodies[0].rows[i].style.background="#666";
} //鼠标移入移出变色操作
oTab.tBodies[0].rows[i].onmouseover = function(){
oOldColor = this.style.background; //保存变色之前的颜色
this.style.background="#999";
};
oTab.tBodies[0].rows[i].onmouseout = function(){
this.style.background=oOldColor; //还原到之前的颜色
}
}

day36—javascript对表格table的操作应用(一)的更多相关文章

  1. day37—javascript对表格table的操作应用(二)

    转行学开发,代码100天——2018-04-22 昨天学习了JavaScript对table的基本操作,包括表格的创建,表格元素的获取,隔行换色及鼠标动作等.今天主要学习table的搜索查询及排序操作 ...

  2. jQuery动态对表格Table进行添加或删除行以及修改列值操作

    jQuery,不仅可以以少量的代码做很多操作,而且兼容性好(各种浏览器,各种版本). 下面用jQuery动态对表格Table进行添加或删除行以及修改列值操作 1.jQuery代码 <script ...

  3. JavaScript(第二十天)【DOM操作表格及样式】

    DOM在操作生成HTML上,还是比较简明的.不过,由于浏览器总是存在兼容和陷阱,导致最终的操作就不是那么简单方便了.本章主要了解一下DOM操作表格和样式的一些知识. 一.操作表格 <table& ...

  4. 使用 iview Table 表格组件修改操作的显示隐藏

    使用 iview Table 表格组件修改操作的显示隐藏,如下图 1.如何设置 table 操作按后台传入的状态值去渲染 不同的按钮? 解决方法 我们在vue2中,动态渲染html 使用的是 retu ...

  5. 采用DOM进行表格的修改操作

    2015-08-31 <html> <head> <title>采用DOM进行表格的修改操作</title> <script language=& ...

  6. JavaScript 实现表格隔行变色

    JavaScript 实现表格隔行变色 版权声明:未经授权,严禁分享! 构建界面 界面HTML代码 <style> #data,th,td{ border: 1px solid #aaaa ...

  7. jQuery 选择表格(table)里的行和列及改变简单样式

    本文只是介绍如何用jQuery语句对表格中行和列进行选择以及一些简单样式改变,希望它可以对jQuery表格处理的深层学习提供一些帮助jQuery对表格(table)的处理提供了相当强大的功能,比如说对 ...

  8. javascript生成表格增删改查 JavaScript动态改变表格单元格内容 动态生成表格 JS获取表格任意单元格 javascript如何动态删除表格某一行

    jsp页面表格布局Html代码 <body onload="show()"> <center> <input type="text" ...

  9. JavaScript创建表格的两种方式

    方式一: var data = [ { id: 1, name: "first", age: 12 }, { id: 2, name: "second", ag ...

随机推荐

  1. Redis功能迅速回忆

  2. PTA第四周作业

    一.本周完成的作业 7-2 选择法排序 (20 分) 本题要求将给定的n个整数从大到小排序后输出. 输入格式: 输入第一行给出一个不超过10的正整数n.第二行给出n个整数,其间以空格分隔. 输出格式: ...

  3. Java初始化块及执行顺序

    理解 初始化块又称为代码块.属于类中的第四大成员.本质上是一个方法,它也有方法体,但没有方法名,没有参数,没有返回,而且也不是通过对象或类名显式调用,而是通过隐式调用 是构造器的补充 语法 [修饰符] ...

  4. [BZOJ2588]Count on a tree(LCA+主席树)

    题面 给定一棵N个节点的树,每个点有一个权值,对于M个询问(u,v,k),你需要回答u xor lastans和v这两个节点间第K小的点权.其中lastans是上一个询问的答案,初始为0,即第一个询问 ...

  5. mysql事务的特性?

    1.原子性(Atomicity):事务中的全部操作在数据库中是不可分割的,要么全部完成,要么均不执 行. 2.一致性(Consistency):几个并行执行的事务,其执行结果必须与按某一顺序串行执行的 ...

  6. linux基础开发软件安装 - java相关

    1.linux在线安装mysql:转自 https://www.cnblogs.com/bigbrotherer/p/7241845.html ,写的很好,简单易用. 开启远程访问:转 https:/ ...

  7. websocket无法注入bean问题解决方案

    websocket服务端往往需要和服务层打交道,因此需要将服务层的一些bean注入到websocket实现类中使用,但是呢,websocket实现类虽然顶部加上了@Component注解,依然无法通过 ...

  8. layui在当前页面弹出一个iframe层,并改变这个iframe层里的一些内容

    layer.open({ type: 2, title: "专家信息", area: ['100%', '100%'], content: '/ZhuanJiaKu/AddZhua ...

  9. JSP学习(1)

    JSP学习(1) 什么是Web应用程序 可以Web访问呢的应用程序,用户只需要浏览器即可访问 静态网页与动态网页 静态网页:网页中内容固定 动态网页:内容通过程序动态显示,自动更新 Java Web应 ...

  10. NTP时间服务器构建

    搭建一个NTP服务器,为整个网络环境中的所有主机提供时间校准服务,具体如下: - 部署一台NTP时间服务器 - 设置时间服务器上层与0.centos.pool.ntp.org同步 - 设置本地服务器层 ...