进行分段而不是
,列表项应该放在ul或ol或dl中,table形式的数据应该仍然用table布局。
为什么要这样做呢?一个很有说服力的原因就是,保证在用户去掉CSS显示的情况下,网页能够尽量有效的将内容的结构层次显示出来。如果全部用div,当去掉CSS之后,整个网页就失去了层次,只剩下一些杂乱的文字碎片。这并不符合Web标准对低配置兼容性的要求。
我下面详细的说一下我对一些html标签的语义的理解:
p br
先说个最简单的。分段要用p标签而不是用br。这个似乎不用多说。但是有时候我们不得不放弃这个原则。一个常见的例子就是论坛发帖,如果我想分段,便打回车。而如此传输到后台并显示出来的,显然就是用
分段的。
table th
由于现在网上大力宣扬div+css的原因,似乎现在谁用table布局谁就是未开化的土著。但我认为这种观点是不正确的。table的含义是table,因此凡是应该以table形式出现的数据,仍然应该用table布局。简单的例子是班级同学的花名册,包括姓名学号性别等等,这明显是一个table形式的数据,因此应该用table布局还得用table。另一个比较值得探讨的例子是,blog里面的日历导航。我曾经有见过一个blog程序,它的日历导航里的各个日期,从1号到30号全用div套好,再使用float:left样式7个一排的排出当月的日历。当我取消浏览器的CSS显示之后,日历的那部分则从1号到30号一竖排下来。我个人认为这是不对的。因为日历应该是一个table形式的数据,因此仍然应该用table布局。当取消css之后,应该仍然按照一排7个的样子归成一个table。
th则是另一个会被忽视的标签。由于CSS的万能,所有的table单元都可以用td加一个class属性搞定。但是从语义上讲,一些table单元应该用th标签。比如上文说到的日历table,里面的“MON TUE WED... SUN”这些标识星期的单元,就应该用th而不是td。
h1-h6
对于h1-h6标签,从语义上讲,它们应该适用于所有标题文字。所以说,一些如