夜鹰教程网-程序员的加油站
 当前位置:文章中心 >> Css3.0_css2.0_html5
如何利用CSS,JavaScript和MooTools制作斑马纹表格
夜鹰教程网 来源:www.yyjcw.com 日期:2016-12-7 5:31:06
简单的斑马纹表格,如果页面上有大量的表格数据时,隔行变色的斑马纹会帮助我们快速阅读,有利于用户体验。我们今天不讨论在动态语言中的方法,只讨论CSS,JavaScript,MooTools 是如何实现的,并有三种可行性方案。

我们的表格

The Html Code:

 

<table id="playlist" cellspacing="0">
	<tbody>
		<tr>
			<td>1</td>
			<td>Lost In The Plot</td>
			<td>The Dears</td>
		</tr>
		<tr>
			<td>2</td>
			<td>Poison</td>
			<td>The Constantines</td>
		</tr>
		<tr>
			<td>3</td>
			<td>Plea From A Cat Named Virtute</td>
			<td>The Weakerthans</td>
		</tr>
		<tr>
			<td>4</td>
			<td>Melissa Louise</td>
			<td>Chixdiggit!</td>
		</tr>
 
		<tr>
			<td>5</td>
			<td>Living Room</td>
			<td>Tegan And Sara</td>
 
		</tr>
		<tr>
			<td>6</td>
			<td>Speed</td>
			<td>Bran Van 3000</td>
		</tr>
		<tr>
			<td>7</td>
			<td>Fast Money Blessing</td>
			<td>King Cobb Steelie</td>
		</tr>
 
		<tr>
			<td>8</td>
			<td>Sore</td>
			<td>Buck 65</td>
		</tr>
		<tr>
			<td>9</td>
			<td>Love Travel</td>
			<td>Danko Jones</td>
		</tr>
		<tr>
			<td>10</td>
			<td>You Never Let Me Down</td>
			<td>Furnaceface</td>
		</tr>	
	</tbody>
 
</table>

 

我们上面所看到的表格,就是我们要美化的表格,要实现斑马纹的表格。

 

方案一 :

在CSS3中有许多的伪类选择器,其中的

 

E:nth-child(n){attribute}

 

它可以匹配父元素中的第n个子元素E。

The CSS3 Code

 

/*获得奇偶数的子元素*/
tr:nth-child(odd)		{ background-color:#eee; }//所有奇数序子元素
tr:nth-child(even)		{ background-color:#fff; }//所有偶数序子元素
/*同上一样的作用*/
tr:nth-child(2n){background-color:#eee;} //返回偶数序的子元素
tr:nth-child(2n+1){ background-color:#fff;} //返回奇数序的子元素

 

方案二 :

The JavaScript Code

 

// this function is need to work around
  // a bug in IE related to element attributes
  function hasClass(obj) {
     var result = false;
     if (obj.getAttributeNode("class") != null) {
         result = obj.getAttributeNode("class").value;
     }
     return result;
  }  
 
function stripe(id) {
 
    // the flag we'll use to keep track of
    // whether the current row is odd or even
    var even = false;
 
    // if arguments are provided to specify the colours
    // of the even & odd rows, then use the them;
    // otherwise use the following defaults:
    var evenColor = arguments[1] ? arguments[1] : "#fff";
    var oddColor = arguments[2] ? arguments[2] : "#eee";
 
    // obtain a reference to the desired table
    // if no such table exists, abort
    var table = document.getElementById(id);
    if (! table) { return; }
 
    // by definition, tables can have more than one tbody
    // element, so we'll have to get the list of child
    // &lt;tbody&gt;s
    var tbodies = table.getElementsByTagName("tbody");
 
    // and iterate through them...
    for (var h = 0; h < tbodies.length; h++) {
 
     // find all the &lt;tr&gt; elements...
      var trs = tbodies[h].getElementsByTagName("tr");
 
      // ... and iterate through them
      for (var i = 0; i < trs.length; i++) {
 
    // avoid rows that have a class attribute
        // or backgroundColor style
    if (!hasClass(trs[i]) && ! trs[i].style.backgroundColor) {
 
         // get all the cells in this row...
          var tds = trs[i].getElementsByTagName("td");
 
          // and iterate through them...
          for (var j = 0; j < tds.length; j++) {
 
            var mytd = tds[j];
 
            // avoid cells that have a class attribute
            // or backgroundColor style
        if (! hasClass(mytd) && ! mytd.style.backgroundColor) {
 
      mytd.style.backgroundColor = even ? evenColor : oddColor;
 
            }
          }
        }
        // flip from odd to even, or vice-versa
        even =  ! even;
      }
    }
  }
window.onload=function(){stripe('playlist', '#fff', '#eee');}

 

在以前MooTools1.1的老版本中是不支持CSS3选择器的,那又如何实现那。

方案三 :

The CSS Code:

 

.odd{
	background:#fff;
	color: #666;
}
.even{
	background-color: #3d80df;
	color: #FFF;	
}

 

The MooTools JavaScript:

 

window.addEvent('domready', function() {
	var count = 0;
	$('table.shade-table tr').each(function(el) {
		el.addClass(count++ % 2 == 0 ? 'odd' : 'even');
	});
});

 

如果你已经使用了MooTools1.2+的版本,我们就可以用MooTools Selectors的伪类选择器,它的语法是类似于CSS3的伪类选择器的。

The MooTools JavaScript:

 

$('table#playlist tr:nth-child(odd)').addClass('odd');
 
$('table#playlist tr:nth-child(even)').addClass('even');
/*
$('table#playlist tr:nth-child(2n+1)').addClass('odd');
 
$('table#playlist tr:nth-child(2n)').addClass('even');*/

 

在鼠标经过时高亮表格行列

The CSS Code:

 

.over{
	background-color:#F00;
	color:#FFF;
}

 

The MooTools JavaScript:

 

$$("table#playlist tr").addEvent('mouseover',function() {this.addClass("over");}).addEvent('mouseout',function() {this.removeClass("over");});
复制链接 网友评论 收藏本文 关闭此页
上一条: 无法屏蔽的网页右下角浮动窗口  下一条: 列表显示文字和图片垂直居中对齐
夜鹰教程网成立于2008年,目前已经运营了将近 13 年,发布了大量关于 html5/css3/C#/asp.net/java/python/nodejs/mongodb/sql server/android/javascript/mysql/mvc/easyui/vue/echarts原创教程。 我们一直都在坚持的是:认证负责、一丝不苟、以工匠的精神来打磨每一套教程,让读者感受到作者的用心。我们默默投入的时间,确保每一套教程都是一件作品,而不是呆板的文字和视频! 目前我们推出在线辅导班试运营,模式为一对一辅导,教学工具为QQ。我们的辅导学科包括 java 、android原生开发、webapp开发、商城开发、C#和asp.net开发,winform和物联网开发、web前端开发,但不仅限于此。 普通班针对的是国内学员,例如想打好基础的大学生、想转行的有志青年、想深入学习的程序员、想开发软件的初学者或者业余爱好者等。 就业办针对即将毕业上岗的大四学生,或者打算转行的初级开发工程师。 留学生班针对的是在欧美、加拿大、澳洲、日本、韩国、新加坡等地留学的中国学子,目的是让大家熟练地掌握编程技能,按时完成老师布置的作业,并能顺利地通过考试。 详细咨询QQ:1416759661   夜鹰教程网  基于角色的权限管理系统(c-s/b-s)。
  夜鹰教程网  基于nodejs的聊天室开发视频教程
  夜鹰教程网  Git分布式版本管理视频教程
  夜鹰教程网  MVC+EasyUI视频教程
  夜鹰教程网  在线考试系统视频教程
  夜鹰教程网  MongoDB视频教程。
  夜鹰教程网 Canvas视频教程
  夜鹰教程网 报表开发视频教程
  热点推荐
什么是css框架
meta标签实现页面的动感效果
CSS半透明滤镜在FIREFOX和IE下面的…
div+css鼠标悬停在div上,div背景色…
纯css下拉菜单特效
div+css的浏览器兼容问题
CSS定义表格线为单一线
CSS滤镜效果收集(全)
列表显示文字和图片垂直居中对齐
在固定位置显示背景图片
网站变换图片的显示方法
在select外面套一个div或span, se…
常用的CSS命名规则
闪字闪字闪字闪字闪字闪字闪字闪字…
css让图片自动适应表格大小
  最近更新
HTTP协议实现文件断点续传
H5实现断点上传
行内元素和块级元素汇总
H5视频直播技术介绍
border-image详解
你必须知道的HTML5的新特性
html5 js控制音乐播放
HTML+CSS代码规范
css3学习笔记 transition与animat…
css3学习笔记Transform
css3学习笔记2D或3D转换
css3学习笔记文本特效
css3学习笔记颜色和透明度
css3学习笔记二
css3学习笔记一

关于我们 | 网站建设 | 技术辅导 | 常见问题 | 联系我们 | 友情链接

夜鹰教程网 版权所有 www.yyjcw.com All rights reserved 备案号:蜀ICP备08011740号3