<li> 标签内部使用 <div> 符合标准和习惯吗?

2011-04-07 16:44:30 +08:00
 darasion
我看网上的介绍,有的说行,有的说不行。

说行的理由是: 标准没有规定不行,可通过验证。
说不行的理由是: <li>内部应该用<span>而不是<div>,说语义上使用<span>更合适。


<ul>
<li><div></div></li>
</ul>

<ul>
<li><span></span></li>
</ul>
14058 次点击
所在节点    问与答
17 条回复
icerunz
2011-04-07 16:46:39 +08:00
我觉得用div大了点~看你具体什么用途了~
keakon
2011-04-07 16:52:26 +08:00
当然符合,li默认就是block元素,block元素可以包含任意block和inline元素
darasion
2011-04-07 16:54:52 +08:00
@keakon 嗯。谢谢。
moplay
2011-04-07 17:09:12 +08:00
我不用
lychee
2011-04-07 17:37:44 +08:00
li的类型貌似是list-item 介于block和inline之间 最好用inline元素吧
Mianco
2011-04-07 18:36:40 +08:00
一般不滥用div
xhslyf
2011-04-07 18:40:12 +08:00
拿去W3C标准检测页面检测一下,能通过就OK。
不过li里放div给人的感觉非常奇怪。
solidh
2011-04-07 18:53:45 +08:00
有时候觉得实在别扭的话,我会给span设一个diasplay:block属性拿来当div用...
darasion
2011-04-07 19:29:17 +08:00
就回帖看来,争议还是很大。。╮(╯_╰)╭。
chone
2011-04-07 19:31:23 +08:00
可能会比较奇怪,主要是div没啥语义。至于标准不标准其实是其次,关键是用户要能得到最好的性能.可以考虑开始使用html5的新标签:)
airyland
2011-04-07 20:29:41 +08:00
觉得不合适。但是HTML5里的a标签都可以放block标签了。
loading
2011-04-07 20:31:48 +08:00
div 和 span 在css面前都一样。
loading
2011-04-07 20:33:04 +08:00
div 和 span 在css面前都一样。
建议两个都不加,保持页面干净,用js加上去
aufula
2011-04-08 00:10:03 +08:00
@keakon 默认是list-item;
aufula
2011-04-08 00:16:42 +08:00
li span的语义就比li div强么? li div还少写点代码。
iugo
2011-04-08 00:28:18 +08:00
个人觉得没问题. 我觉得之所以感觉这样用奇怪是因为大家把 <li> 看得小了.
keakon
2011-04-08 01:17:57 +08:00
@aufula 这么说吧,HTML是一门表语义的语言,设计者的出发点就是为了表达语义。

例如我们在word中写一本书时,必然要分为章、节之类的片段,这些片段都是自动编号的。在HTML中,它天然就应该是ol、li的形式,因为这样才能表达章、节之间的语义关系。

而在写这些部分时,我们不可避免地还需要添加注释、代码、表单之类的块元素,那么li必须设计成能包含块元素。

一个元素不仅有外在的展现形式,还有其内在的展现形式,这就是inline-block存在的理由。list-item显然是说它的外在展现形式,如果设计者希望写得这么复杂的话,或许今天你能看到的应该是更不易混淆的inline-inline、block-block和list-item-block。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/11106

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX