作家
登录

最大限度的分离table的样式与结构

作者: 来源:www.28hudong.com 2012-11-19 22:22:34 阅读 我要评论

但CSS+XHTML的兴起,使很多人开始妖魔化table这一标签,甚至以页面中是否有table来评判页面质量,这是不对的. table也有它存在的作用,很多页面功能(比如数据表格类,表单对齐等)用table实现远比用div实现起来简单明了.当然,本文不是为table平反的, 我只是想告诉大家如何最大限度的分离table的样式与结构.分离样式,当然离不开CSS,而对于table标签,还有更多私有HTML属性可以利用.比如,thead,tr,th,td,tbody,tfoot,colgroup,scope.而本文正是利用这些属性,把样式从table中分离出来.请看下图:这是一个有6种背景色的table,如果按常规的table定义,想必大家都知道这个表格写出来该有多麻烦,你得一个个单元格的去加样式,加属性.其实,上面的效果完全可以有着很明了简洁的结构,也可以不通过修改html页面来改变它的样式. <!DOCTYPE html> <html> <head> <meta charset="gb2312" /> <title>最大限度的分离table的样式与结构~@Mr.Think</title> <style> body{font-size:0.8em;letter-spacing:1px;font-family:"微软雅黑"; line-height:1.8em} h1{font-size:1em; font-weight:normal} h1 a{background:#CFF; padding:2px 3px; text-decoration:none} h1 a:hover{background:#eee; text-decoration:underline} table{border-collapse:collapse} table#itab{border:1px solid #999; width:50em; margin:0 auto} #itab caption{font-size:1em; font-weight:normal; color:#a40000} #itab thead{background:#ffc} #itab td,table#itab th{border:1px solid #ccc} #itab tfoot{background:#fcc} #itab .linenum{width:15%; background:#0cf} #itab .id-1{width:20%; background:#cf9} #itab .id-2{width:25%; background:#eee} #itab .id-3{width:30%; background:#9ff} </style> </head> <body> <h1><a href="http://mrthink.net/">Mr.Think的个人博客</a> @专注前端技术,热爱PHP,崇尚简单生活.</h1> <table id="itab"> <caption>最大限度的分离table的样式与结构,Uh Oh!</caption> <colgroup> <col class="linenum"> <col class="id-1"> <col class="id-2"> <col class="id-3"> </colgroup> <thead> <tr><th>LINENUM</th><th>ID-1</th><th>ID-2</th><th>ID-3</th></tr> </thead> <tbody> <tr><td>1</td><td>A</td><td>CY</td><td>I</td></tr> <tr><td>2</td><td>Br</td><td>S</td><td>KMQ</td></tr> <tr><td>3</td><td>HTC</td><td>LLI</td><td>P</td></tr> <tr><td>4</td><td>ACC</td><td>G</td><td>QO</td></tr> <tr><td>5</td><td>Z</td><td>AHD</td><td>M</td></tr> </tbody> <tfoot> <tr><th>LINE.NO</th><th>ID-1</th><th>ID-2</th><th>ID-3</th></tr> </tfoot> </table> <strong>扩展阅读</strong><a href="http://mrthink.net/javascript-tagnames-highlight/">奇或偶数行高亮显示及鼠标划过高亮显示类</a> </body> </html> 提示:您可以先修改部分代码再运行下面是核心代码分析:HTML代码: 复制代码代码如下: <table id="itab"> <caption>最大限度的分离table的样式与结构,Uh Oh!</caption> <colgroup> <col class="linenum"> <col class="id-1"> <col class="id-2"> <col class="id-3"> </colgroup> <thead> <tr><th>LINENUM</th><th>ID-1</th><th>ID-2</th><th>ID-3</th></tr> </thead> <tbody> <tr><td>1</td><td>A</td><td>CY</td><td>I</td></tr> <tr><td>2</td><td>Br</td><td>S</td><td>KMQ</td></tr> <tr><td>3</td><td>HTC</td><td>LLI</td><td>P</td></tr> <tr><td>4</td><td>ACC</td><td>G</td><td>QO</td></tr> <tr><td>5</td><td>Z</td><td>AHD</td><td>M</td></tr> </tbody> <tfoot> <tr><th>LINE.NO</th><th>ID-1</th><th>ID-2</th><th>ID-3</th></tr> </tfoot> </table> CSS代码: 复制代码代码如下: table#itab{border-collapse:collapse; border:1px solid #999; width:50em; margin:0 auto} #itab caption{font-size:1em; font-weight:normal; color:#a40000} #itab thead{background:#ffc} #itab td,table#itab th{border:1px solid #ccc} #itab td{padding-left:0.8em} #itab tfoot{background:#fcc} #itab .linenum{width:15%; background:#0cf} #itab .id-1{width:20%; background:#cf9} #itab .id-2{width:25%; background:#eee} #itab .id-3{width:30%; background:#9ff} 如此一看,是不是明了很多.无非是把表格结构化,然后充分利用thead,th,tfoot等table私有属性定义不同的样式.这里不得不提一下colgroup标签,在本文DEMO中,它起到了很重要的作用.但个人认为,它也只能做一些定宽背景定义.它有一个很致命的弱点,不兼容. 比如用它来给列定义字体颜色,ie6下是正常,但其他浏览器好像都是不支持的(如果一定要用它来定义列的字体颜色和对齐方式,可以利用CSS高级选择器first-child为ie6外的浏览器定义样式,暂不详述).但不可否认colgroup是一个很实用的标签. 表格样式的分离,个人觉得完全用CSS分离也不是一个明智的选择,当有些效果CSS无法实现时,或者实现起来比较麻烦时,我们完全可以用JavaScript来实现你想呈现的效果.比如隔行换色,鼠标划过变色等效果(可扩展阅读奇或偶数行高亮显示及鼠标划过高亮显示类). 多思考,多发现,多实践.HTML的每一个标签如同我们身体的每一个器官,都有个它特定的功能,好好利用它们,相信能带给你很多惊喜.

  推荐阅读

  CSS 网页背景渐变实现代码

网页背景渐变是经常用到的效果,下面用的滤镜,当然在非IE下是没效果的。 一、从上往下渐变 body{FILTER: progid: DXImageTransform.Microsoft.Gradient(gradientType=0,startColorStr=#ffffff,endColorStr=#000>>>详细阅读


本文标题:最大限度的分离table的样式与结构

地址:http://www.17bianji.com/kaifa2/CSS/16551.html

关键词: 探索发现

乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

网友点评
自媒体专栏

评论

热度

精彩导读
栏目ID=71的表不存在(操作类型=0)