day36—javascript对表格table的操作应用(一)
转行学开发,代码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的操作应用(一)的更多相关文章
- day37—javascript对表格table的操作应用(二)
转行学开发,代码100天——2018-04-22 昨天学习了JavaScript对table的基本操作,包括表格的创建,表格元素的获取,隔行换色及鼠标动作等.今天主要学习table的搜索查询及排序操作 ...
- jQuery动态对表格Table进行添加或删除行以及修改列值操作
jQuery,不仅可以以少量的代码做很多操作,而且兼容性好(各种浏览器,各种版本). 下面用jQuery动态对表格Table进行添加或删除行以及修改列值操作 1.jQuery代码 <script ...
- JavaScript(第二十天)【DOM操作表格及样式】
DOM在操作生成HTML上,还是比较简明的.不过,由于浏览器总是存在兼容和陷阱,导致最终的操作就不是那么简单方便了.本章主要了解一下DOM操作表格和样式的一些知识. 一.操作表格 <table& ...
- 使用 iview Table 表格组件修改操作的显示隐藏
使用 iview Table 表格组件修改操作的显示隐藏,如下图 1.如何设置 table 操作按后台传入的状态值去渲染 不同的按钮? 解决方法 我们在vue2中,动态渲染html 使用的是 retu ...
- 采用DOM进行表格的修改操作
2015-08-31 <html> <head> <title>采用DOM进行表格的修改操作</title> <script language=& ...
- JavaScript 实现表格隔行变色
JavaScript 实现表格隔行变色 版权声明:未经授权,严禁分享! 构建界面 界面HTML代码 <style> #data,th,td{ border: 1px solid #aaaa ...
- jQuery 选择表格(table)里的行和列及改变简单样式
本文只是介绍如何用jQuery语句对表格中行和列进行选择以及一些简单样式改变,希望它可以对jQuery表格处理的深层学习提供一些帮助jQuery对表格(table)的处理提供了相当强大的功能,比如说对 ...
- javascript生成表格增删改查 JavaScript动态改变表格单元格内容 动态生成表格 JS获取表格任意单元格 javascript如何动态删除表格某一行
jsp页面表格布局Html代码 <body onload="show()"> <center> <input type="text" ...
- JavaScript创建表格的两种方式
方式一: var data = [ { id: 1, name: "first", age: 12 }, { id: 2, name: "second", ag ...
随机推荐
- STL 仿函数(函数对象)
##定义 仿函数(functor):一种具有函数性质的对象. 仿函数在C++中的新名称为函数对象(function object). 仿函数类对象像函数一样被调用,调用仿函数类对象时,实际调用的是仿函 ...
- Java相关面试题总结+答案(八)
[RabbitMQ] 135. RabbitMQ 的使用场景有哪些? 抢购活动,削峰填谷,防止系统崩塌. 延迟信息处理,比如 10 分钟之后给下单未付款的用户发送邮件提醒. 解耦系统,对于新增的功能可 ...
- 使用Redis共享用户登录成功的信息
一.问题 比如CSDN,开源中国等等网站,用户登录后不一定什么时候就会把你T了,意思就是不一定哪天在打开网站的时候就让你重新登录.这是怎么回事呢? 再比如:如果存到将用户信息存到Redis了,不清除的 ...
- 循环结构 :do-while
循环结构 :do-while 循环四要素: 1.初始化条件 2.循环条件 3.循环体 4.迭代条件 格式: 1.初始化条件 do{ 3.循环体 4.迭代条件 }while(2.循环条件); publi ...
- #python# error:illegal multibyte sequence
读取html遇到illegal multibyte sequence 1.第一种情况:更换编码方式 查看网页源码,找到charset,得到该网页编码方式 <meta http-equiv=&qu ...
- jQuery学习总结02-筛选
一.筛选 1.eq(index|-index) 说明:获取当前链式操作中第N个jQuery对象,返回jQuery对象,类似的有get(index),不过get(index)返回的是DOM对象 示例: ...
- Dubbo源码学习总结系列七---注册中心
Dubbo注册中心是框架的核心模块,提供了服务注册发现(包括服务提供者.消费者.路由策略.覆盖规则)的功能,该功能集中体现了服务治理的特性.该模块结合Cluster模块实现了集群服务.Dubbo管理控 ...
- 二、Rabbit使用-初次测试
RabbitMQ提供了后台管理的页面,如果想使用该页面,需要进入安装rabbitmq的安装目录,运行以下cmd命令 rabbitmq-plugins enable rabbitmq_managemen ...
- Python之列表、元组、字典、集合及字符串的详细使用
1.列表 列表相当与C++中的数组,是有序的项目, 通过索引进行查找,但使用起来却方便很多,具体的操作看代码,自己实践一次就非常简单了. 注:列表一般用中括号“[ ]” #列表(数组) name_li ...
- Mybatis中dao层实现
在上一个笔记中继续: 因为要基于dao层,那么我们只需要又一个dao的接口,和一个mapper的文件就可以测试了. 但是基于dao层的时候需要规范: Mapper.xml文件中的namespace与m ...