重新发现HTML表格

根据我最近的一些实践以及在和一些读者进行关于HTML表格的使用问题沟通之后,决定写这篇文章。总的来说,我注意到由于误导性信息,他们对于table的使用有种先入为主的厌恶。事实上很多人会说”我看到永远不应该使用表格”的说法,但是这绝对是错误的!这个建议只是针对使用HTML表格来定义网页的布局,但是表格在方便的排列数据信息行和列方面非常完美,而且如果你一定要在一个页面上显示表列数据,你就不得不使用它们!为什么不呢?然而,在这种情况下,一些人无视了用于table的某些HTML标签的存在并且不知道该如何正确的使用它们。

 

HTML有10个表格相关标签。下面是一个带有简介的列表,但是首先,文档要被正确的定义在HTML 4.01/XHTML 1或HTML 5下面:

  • <caption> 定义表格标题(4, 5)

  • <col> 为表格的列定义属性(4, 5)

  • <colgroup> 定义表格列的分组(4, 5)

  • <table> 定义表格(4, 5)

  • <tbody> 定义表格主体(4, 5)

  • <td> 定义一个单元格 (4, 5)

  • <tfoot> 定义表格的表注(底部)(4, 5)

  • <th> 定义表格的表头 (4, 5)

  • <thead> 定义表格的表头(4, 5)

  • <tr> 定义表格的行(4, 5)

一个基本的表格结构如下:

它包含一个标题、头部、主体和底部。正确的HTML元素顺序是:

  1. <table>

  2. <caption>

  3. <thead>

  4. <tfoot>

  5. <tbody>

你也可以使用<col><colgroup> 来定义表格的列或为列分组:

  1. <table>

  2. <caption>

  3. <colgroup>

  4. <col>

  5. <thead>

  6. <tfoot>

  7. <tbody>

下面是一个正确的表格结构实例:

<table border="1"><caption>Table caption here</caption><colgroup span="1" style="background:#DEDEDE;"/><colgroup span="2" style="background:#EFEFEF;"/> 	<!-- Table Header--><thead><tr><th>Head 1</th><th>Head 2</th><th>Head 3</th></tr></thead> 	<!-- Table Footer--><tfoot><tr><td>Foot 1</td><td>Foot 2</td><td>Foot 3</td></tr></tfoot> 	<!-- Table Body--><tbody> 
		<tr><td>A</td><td>B</td><td>C</td></tr><tr><td>D</td><td>E</td><td>F</td></tr></tbody></table>

在浏览器中的结果如下图所示:

关于表格的一些技巧

  • 根据w3schools的解释和用法,在一个table定义中,<tfoot>元素必须出现在<tbody>之前,这样,浏览器就可以在接受到所有数据之前呈现表注了。另外,如果不是这个顺序,将不能通过W3C的HTML4和XHTML验证,无论你声明哪种DTD。(了解更多)。

  • 在 HTML 4.01 中,表格的alignbgcolor属性不赞成使用,所以在HTML 5中不再有任何table的属性被支持(事实上,在XHTML 1.0 Strict DTD中已经不支持&rdquo;align&rdquo;和&rdquo;bgcolor&rdquo;属性了);

  • 所有主流浏览器都支持<colgroup> 标签,但是Firefox、Chrome 以及 Safari 仅支持 colgroup 元素的 span 和 width 属性;

  • css中的empty-cells:show|hide 可以设定空单元格是否显示边框。注意,这个需要设置在table而不是td/th中。IE6中比较容易遇到该问题;

  • css中的border-collapse:collapse | separate 可以设置表格的边框是否被合并成一个边框;

  • css中的border-spacing属性等效于table的cellspacing属性。

为了实现现在所提倡的表现和结构分离的开发模式,前端观察建议将页面中所有与表现层有关的东东,都用CSS来控制,不用HTML自带的属性来控制页面的表现,而table是最容易被忽略的一个。

关于table的更多详细内容可以查看W3C的文档: w3 Introduction to tables

最后留一个非常简单的问题给大家,CSS的哪个属性等效于table的cellpadding属性?

中文原文:重新发现HTML表格
整理自:Woork

Pader 2009-12-11 3

phpDesinger7 简体中文语言文件

最近因为公司项目需要,也因为自己的需要吧,开始想换一个专业一点的IDE了,公司推荐是用ZendStudio,但是这玩意儿太大了,安装程序好几百兆,打开占用也要上百兆的内存,速度还很慢,实在觉得没趣。昨天无意中发现了一款叫 phpDesinger 的软件,先装了一个6的版本,发现居然是多语言支持的,哈哈,这点比ZS要好,仔细研究了下发现跟ZS几乎一样,后来换了个最新的7.0版本的,功能同样强大,而且安装程序只有三十兆,打开速度和内存占用比ZS都要好多了。跟往常一样,我要设置一下里面一些高亮与缩进之类的,哈哈,但是问题随后而来了,这个里面自带的简体中文语言太奇怪了,有很多看了半天没看懂,而且7里面的语言包居然是6的,非常郁闷,看了一下语言文件,里面的语言几乎就是用软件翻译的,语义真是乱七八糟,于是花了将近一天的时候将中文语言全部重新翻译了一遍,包括最新的7的一些未翻译的,今天早上继续翻译了一些,也终于把整个翻译完成了,哈哈。
哎,可是我总是无法放手那可爱的Notepad2,Notepad2的编辑菜单下的功能和设置等真是非常的方便和顺手,不管是ZendStudio还是phpDesinger在这方面都无法跟Notepad2比,而且在语言和字体控制支持方面Notepad2都是非常的强,我在想要是能把Notepad2的编辑窗口集成到phpDesinger中该多好啊,哈哈,我YY了。

语言文件下载:[attach=199]
下载后将 zh-cn.lng 覆盖程序目录中 Languages 目录下的同名文件,然后在 View - Language 中选择 “中文(简体,中国)”

phpDesinger 和 Notepad2
 

Pader 2009-12-3 2

JS 鼠标经过内部时触发 onmouseout 函数的修补函数 mouseleave

相信做过下拉菜单的朋友都会遇到过鼠标在经过菜单内部元素上面的时候也触发父元素的 onmouseout 导致菜单隐藏的问题,郁闷吧,我曾经很郁闷,IE 有 onmouseleave 和 onmouseenter 这两个东西,jQuery 也有 mouseleave 和 mouseenter,可是我不想用 jQuery 又想兼容多浏器咱办,我搞来搞去写了这么一个后补方案,用法见里面的注释。

  1. /*  
  2.     鼠标 onmouseleave 修复事件,兼容IE和FF  
  3.     参数e 是对象传递的触发事件 FF下想访问event对象必须传递event参数  
  4.     参数o 是目标DIV对象  
  5.     onmouseout="mouseleave(event,this,function(){alert('leave')})";  
  6. */    
  7. function mouseleave(e,o,funcCallBack) {  
  8.     // FF 下判断鼠标是否离开  
  9.     if(window.navigator.userAgent.indexOf("MSIE") == "-1") {  
  10.         var reltg = e.relatedTarget ? e.relatedTarget : e.type == 'mouseout' ? e.toElement : e.fromElement;     
  11.         while (reltg && reltg != o)     
  12.             reltg = reltg.parentNode;     
  13.         if(reltg != o) {  
  14.             funcCallBack();  
  15.         }  
  16.     } else {  
  17.         // IE  
  18.         if(o.contains(event.toElement ) == false) funcCallBack();  
  19.     }  

 

Pader 2009-10-29 1

JS 获取鼠标位置

以前写了一个获取鼠标位置的函数,但是是放在页面 onmousemove 监听事件中,有时候也不太好用,最近在做一个文件管理器的时候很多都用到右键菜单,于是有了这个。

  1. /*  
  2.     获取鼠标座标,需传递 event  
  3. */ 
  4. var getEventMouseLocation = function(e) {  
  5.     var loc = {};  
  6.     var objEvent = e ? e : (window.event ? window.event : null);  
  7.     if(window.navigator.userAgent.indexOf("MSIE") == "-1") {  
  8.         loc.x = objEvent.pageX;  
  9.         loc.y = objEvent.pageY;  
  10.     } else {  
  11.         loc.x = objEvent.x + document.documentElement.scrollLeft;  
  12.         loc.y = objEvent.y + document.documentElement.scrollTop;  
  13.     }  
  14.     return loc;  
  15. }; 

在使用的时候尽可能的传递 event,但是你如果实在不想传也行。例:

  1. <script type="text/javascript"> 
  2. function helloworld(e) {  
  3.     var loc = getEventMouseLocation(e);  
  4.     alert(loc.x + ":" + loc.y);  
  5. }  
  6. </script> 
  7. <button onclick="helloworld(event);">点击</button> 
Pader 2009-10-29 0

项目中十件最痛苦的事

NO.1:需求变更,我变我变我变变变!
痛苦等级:★★★★★
原因:没完没了的开会,没完没了的争吵,没完没了的修改……最后,项目失败,世界都清净了。

NO.2:我们需要文档吗?不需要吗?
痛苦等级:★★★★★
原因:需求?在我脑子里!概要设计?哎,老大呀,工期紧啊,没时间写啊!详细设计?放心!我写完代码一定给你补起来!

NO.3:松散的团队
痛苦等级:★★★★★
原因:你这做的什么东西!我没时间写!这件事应该你做!这不是我的责任!这人不是我兄弟!这件事我不知道!叫他去做!

NO.4:BUG!超级多的BUG!
痛苦等级:★★★★☆
原因:改了又改改了又改改了又改改了又改改了又改改了又改改了又改改了又改改了又改改了又改改了又改改了又改

NO.5:规范?那是无能者的借口!
痛苦等级:★★★★☆
原因:规范?麻烦!我写的代码你放心好了!出了问题我负责改就是了!

NO.6:不懂技术的管理者
痛苦等级:★★★★
原因:我看那XXX不错啊,咱们的OA系统也加一个?不行?那加个XX?又不行?小伙子,你这技术还要加强呀!

NO.7:口吐莲花的销售,只有想不到没有做不到。
痛苦等级:★★★★
原因:BUG?保证明天给你改好!啥ERP?小意思,一个月给你搞定!安全?完全没问题!并发?至少几千万!哈哈。

NO.8:技术狂人
痛苦等级:★★★☆
原因:现在还有谁用这技术呀!用XX吧!多牛呀!……交货?等几天,这有个技术上的缺陷,我要联系下XX公司呢!

NO.9:通知一下,明天早上开会啊!
痛苦等级:★★★
原因:有事要开会,没事也开会,好事大家会,出事大家推。上班没干啥,一直忙开会。

NO.10:这是我的兄弟,你多关照啊!
痛苦等级:★★
原因:听说你公司招人?这我铁哥们,你多关照啊!经验没有,技术不会,不过没关系,可以学嘛!哈哈!
 

Pader 2009-10-19 0