V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
fetich
V2EX  ›  问与答

请教有关前端 CSS float、clear 属性的相关问题

  •  
  •   fetich · 2016-03-17 23:09:28 +08:00 · 974 次点击
    这是一个创建于 2980 天前的主题,其中的信息可能已经有所发展或是发生改变。

    第一个问题:
    在实践 MDN CSS Getting Started tutorial - Layout Floats 一节时,结果和图示有出入。因为有 h3 {clear: left;} 这条规则,所以 (B) Numbered paragraphs 应当在无序列表的下方,浏览器的结果也是如此。
    请问是不是 MDN 出错了?

    第二个问题:
    直接上代码……
    HTML

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Document</title>
        <link rel="stylesheet" href="style3.css" />
    </head>
    <body>
        <div class="wrapper">
    
        <p class="black">Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Phasellus sit amet diam. Duis mattis varius dui. Suspendisse eget dolor.</p>
        <p class="red">Lorem ipsum dolor sit amet, consectetuer adipiscing elit.</p>
        <img id="yellow-pin" src="https://mdn.mozillademos.org/files/924/Yellow-pin.png" alt="Yellow pin" />
        <p class="left">This paragraph clears left.</p>
        </div>
    </body>
    </html>
    

    CSS

    .wrapper{
        border:1px solid black;
        padding:10px;
    }
    .left {
        border: 1px solid black;
        clear: left;
    }
    .black {
        float: left;
        margin: 0px;
        background-color: black;
        color: #fff;
        width: 20%;
    }
    .red {
        float: left;
        margin: 0px;
        background-color: red;
        width:20%;
    }
    p {
        width: 50%;
    }
    #yellow-pin {
        border: 2px dotted #ccc;
        clear: left;
    }
    

    结果 Imgur,我给图片标签加上了 clear: left,但图片仍在红色背景块的右侧,难道不应该位于黑色背景块和第三个 p 标签之间么? 请各位前端前辈指教,谢谢。

    2 条回复    2016-03-18 11:19:18 +08:00
    kamal
        1
    kamal  
       2016-03-18 00:30:18 +08:00   ❤️ 1
    1 ,你是对的,截图中演示部分的代码跟上面提到的不一样,没有 h3 标签,粗体字也没有加上 clear:left;
    加上后就跟你描述的一样了。
    2 ,图片是 inline 元素,但是表现的像是 inline-block 元素
    http://stackoverflow.com/questions/2402761/is-img-element-block-level-or-inline-level
    http://stackoverflow.com/questions/9928211/why-does-image-use-display-inline-but-behaves-like-an-inline-block-element

    ps: 贴代码可以用 jsbin.com ,或者 jsfiddle.net 。可以直接看源码看效果。
    fetich
        2
    fetich  
    OP
       2016-03-18 11:19:18 +08:00
    @kamal 谢谢您的回复。躺床上的时候想了想,是不是跟块状、内联元素有关系,没想到还真是。;-)
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   4346 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 45ms · UTC 05:21 · PVG 13:21 · LAX 22:21 · JFK 01:21
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.