darasion
V2EX  ›  问与答

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

  •  
  •   darasion · Apr 7, 2011 · 14731 views
    This topic created in 5517 days ago, the information mentioned may be changed or developed.
    我看网上的介绍,有的说行,有的说不行。

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


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

    <ul>
    <li><span></span></li>
    </ul>
    17 replies    1970-01-01 08:00:00 +08:00
    icerunz
        1
    icerunz  
       Apr 7, 2011
    我觉得用div大了点~看你具体什么用途了~
    keakon
        2
    keakon  
       Apr 7, 2011
    当然符合,li默认就是block元素,block元素可以包含任意block和inline元素
    darasion
        3
    darasion  
    OP
       Apr 7, 2011
    @keakon 嗯。谢谢。
    moplay
        4
    moplay  
       Apr 7, 2011
    我不用
    lychee
        5
    lychee  
       Apr 7, 2011
    li的类型貌似是list-item 介于block和inline之间 最好用inline元素吧
    Mianco
        6
    Mianco  
       Apr 7, 2011
    一般不滥用div
    YFZZ
        7
    YFZZ  
    PRO
       Apr 7, 2011
    拿去W3C标准检测页面检测一下,能通过就OK。
    不过li里放div给人的感觉非常奇怪。
    solidh
        8
    solidh  
       Apr 7, 2011 via iPod
    有时候觉得实在别扭的话,我会给span设一个diasplay:block属性拿来当div用...
    darasion
        9
    darasion  
    OP
       Apr 7, 2011
    就回帖看来,争议还是很大。。╮(╯_╰)╭。
    chone
        10
    chone  
       Apr 7, 2011
    可能会比较奇怪,主要是div没啥语义。至于标准不标准其实是其次,关键是用户要能得到最好的性能.可以考虑开始使用html5的新标签:)
    airyland
        11
    airyland  
       Apr 7, 2011
    觉得不合适。但是HTML5里的a标签都可以放block标签了。
    loading
        12
    loading  
       Apr 7, 2011
    div 和 span 在css面前都一样。
    loading
        13
    loading  
       Apr 7, 2011
    div 和 span 在css面前都一样。
    建议两个都不加,保持页面干净,用js加上去
    aufula
        14
    aufula  
       Apr 8, 2011
    @keakon 默认是list-item;
    aufula
        15
    aufula  
       Apr 8, 2011
    li span的语义就比li div强么? li div还少写点代码。
    iugo
        16
    iugo  
       Apr 8, 2011
    个人觉得没问题. 我觉得之所以感觉这样用奇怪是因为大家把 <li> 看得小了.
    keakon
        17
    keakon  
       Apr 8, 2011
    @aufula 这么说吧,HTML是一门表语义的语言,设计者的出发点就是为了表达语义。

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

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

    一个元素不仅有外在的展现形式,还有其内在的展现形式,这就是inline-block存在的理由。list-item显然是说它的外在展现形式,如果设计者希望写得这么复杂的话,或许今天你能看到的应该是更不易混淆的inline-inline、block-block和list-item-block。
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   2631 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 51ms · UTC 15:49 · PVG 23:49 · LAX 08:49 · JFK 11:49
    ♥ Do have faith in what you're doing.