表格隔行换色,鼠标经过时高亮显示

在网页的,表格的布局经常可见,当表格的行数非常多的,很容易引起用户的视觉疲劳,而且容易让用户把相邻两行的数据看错。我们可以通过隔行换色以及高亮的方法的来改善用户体验!

如果用css来实现,前台的代码会略显不优雅,比如在奇数行我们需要添加<tr class="odd">这样的代码来实现隔行换色,而且如果是从后台动态输出的网页,这是无法实现的,除非用程序去控制。tr:hover 在ie6下是不支持的。所以还是不能完全满足我们的要求。

这里我们可以用javascript来帮我们实现以上需求。主要就是操作DOM。

首先看完整代码示例:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta content="text/html; charset=utf-8" http-equiv="Content-Type" />
<title>stripe tables</title>
<style type="text/css">
	* {
		padding:0;
		margin:0;
	}

	body {
		font-family:verdana;
		font-size:12px;
	}

	.content {
		width:550px;
		margin:20px auto;
	}

	.content h1 {
		font-family:'微软雅黑';
		font-size:18px;
		padding-bottom:5px;
	}

	table {
		width:100%;
	}

	th, td {
		padding:6px 0;
		text-align:center;
	}

	th {
		background-color:#007D28;
		color:#ffffff;
	}
	
	tr {
		background-color:#E8FFE8;
	}
	
	.odd {
		background-color:#FFF3EE;
	}
	
	.highlight {
		background-color:#E0E0E0;
}

</style>

<script type="text/javascript">
	//动态给js添加class属性
	function addClass(element, value) {
		if(!element.className) {
			element.className = value; //如果element本身不存在class,则直接添加class为value的值
		} else {
			element.className += " "+value; //如果element之前有一个class值,注意中间要多一个空格,然后再加上value的值
		}
	}
	
	//隔行换色
	function stripeTable() {
		var tables = document.getElementsByTagName("table"); //遍历文档中的所有table
		for(var i=0; i<tables.length; i++) {
			var rows = document.getElementsByTagName("tr");
			for(var j=0; j<rows.length; j++) {
				if(j%2 == 0) {
					addClass(rows[j], "odd"); //如是偶数行,则添加class为odd的属性
					//rows[j].setAttribute("class", "odd");
				}
			}
		}
	}
	
	//鼠标经过时高亮显示
	function highlightRows() {
		var rows = document.getElementsByTagName("tr");
		for(var i=0; i<rows.length; i++) {
			rows[i].oldClassName = rows[i].className; //首先保存之前的class值
			rows[i].onmouseover = function() {
				addClass(this, "highlight"); //鼠标经过时添加class为highlight的值
			}
			rows[i].onmouseout = function() {
				this.className = this.oldClassName; //鼠标离开时还原之前的class值
			}
		}
	}
	
	window.onload = function() {
		stripeTable();
		highlightRows();
	}
</script>



</head>

<body>
<div class="content">
	<h1>会员信息表</h1>
	<table summary="user infomation table">
		<thead>
			<tr>
				<th>会员ID</th>
				<th>会员名</th>
				<th>邮箱</th>
				<th>会员组</th>
				<th>城市</th>
				<th>注册时间</th>
			</tr>
		</thead>
		<tbody>
			<tr>
				<td>126</td>
				<td>webw3c</td>
				<td>este@126.com</td>
				<td>普通会员</td>
				<td>武汉</td>
				<td>2011-04-01</td>
			</tr>
			<tr>
				<td>127</td>
				<td>test001</td>
				<td>test001@126.com</td>
				<td>普通会员</td>
				<td>北京</td>
				<td>2011-04-03</td>
			</tr>
			<tr>
				<td>128</td>
				<td>wuliao</td>
				<td>wuliao@126.com</td>
				<td>普通会员</td>
				<td>南昌</td>
				<td>2011-04-04</td>
			</tr>
			<tr>
				<td>129</td>
				<td>tired</td>
				<td>tired@126.com</td>
				<td>中级会员</td>
				<td>北京</td>
				<td>2011-04-06</td>
			</tr>
			<tr>
				<td>130</td>
				<td>tiredso</td>
				<td>tireds0@126.com</td>
				<td>中级会员</td>
				<td>武汉</td>
				<td>2011-04-06</td>
			</tr>
			<tr>
				<td>131</td>
				<td>javascript</td>
				<td>js2011@126.com</td>
				<td>中级会员</td>
				<td>武汉</td>
				<td>2011-04-08</td>
			</tr>
			<tr>
				<td>132</td>
				<td>jQuery</td>
				<td>jQuery@126.com</td>
				<td>高级会员</td>
				<td>北京</td>
				<td>2011-04-12</td>
			</tr>
		</tbody>
	</table>
</div>
</body>

</html>

javascript部分代码:
<script type="text/javascript">
	//动态给js添加class属性
	function addClass(element, value) {
		if(!element.className) {
			element.className = value; //如果element本身不存在class,则直接添加class为value的值
		} else {
			element.className += " "+value; //如果element之前有一个class值,注意中间要多一个空格,然后再加上value的值
		}
	}
	
	//隔行换色
	function stripeTable() {
		var tables = document.getElementsByTagName("table"); //遍历文档中的所有table
		for(var i=0; i<tables.length; i++) {
			var rows = document.getElementsByTagName("tr");
			for(var j=0; j<rows.length; j++) {
				if(j%2 == 0) {
					addClass(rows[j], "odd"); //如是偶数行,则添加class为odd的属性
					//rows[j].setAttribute("class", "odd");
				}
			}
		}
	}
	
	//鼠标经过时高亮显示
	function highlightRows() {
		var rows = document.getElementsByTagName("tr");
		for(var i=0; i<rows.length; i++) {
			rows[i].oldClassName = rows[i].className; //首先保存之前的class值
			rows[i].onmouseover = function() {
				addClass(this, "highlight"); //鼠标经过时添加class为highlight的值
			}
			rows[i].onmouseout = function() {
				this.className = this.oldClassName; //鼠标离开时还原之前的class值
			}
		}
	}
	
	window.onload = function() {
		stripeTable();
		highlightRows();
	}
</script>

css部分代码:
	* {padding:0;margin:0;	}

	body {font-family:verdana;font-size:12px;	}

	.content {width:1024px; margin:20px auto;	}

	.content h1 {font-family:'微软雅黑'; font-size:18px; padding-bottom:5px;	}

	table {	width:100%;	}

	th, td {padding:6px 0;text-align:center;}

	th {background-color:#007D28;color:#ffffff;	}
	
	tr {background-color:#E8FFE8;}
	
	.odd {background-color:#FFF3EE;	}
	
	.highlight {background-color:#E0E0E0;}

</style>


1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 、5资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值