• display: block; 和 display: inline; 的区别


    dispaly: block 形成一个块框,元素特点:

    1. 处于常规流中时,如果width没有设置,会自动填充满父容器

    2. 可以应用margin/padding

    3. 在没有设置高度的情况下会扩展高度以包含常规流中的子元素

    4. 处于常规流中时布局时在前后元素位置之间(独占一个水平空间)

    5. 忽略vertical-align

    display: inline 形成一个行内框,元素特点:

    1. 水平方向上根据direction依次布局

    2. 不会在元素前后进行换行

    3. 受white-space控制

    4. margin/padding在竖直方向上无效,水平方向上有效

    5. width/height属性对非替换行内元素无效,宽度由元素内容决定

    6. 非替换行内元素的行框高由line-height确定,替换行内元素的行框高由height,margin,padding,border决定

    7. 浮动或绝对定位时会转换为block

    8. vertical-align属性生效(经测试,貌似有问题,待处理)

    关于图片位置的一个小例子

    <style>
    	img.top { vertical-align: text-top; }
    	img.bottom { vertical-align: text-bottom; }
    	img.middle { vertical-align: middle; }
    </style>
    
    
    <div>An <img src="https://mdn.mozillademos.org/files/12245/frame_image.svg" alt="link" width="32" height="32" /> image with a default alignment.</div>
    
    <div>An <img class="top" src="https://mdn.mozillademos.org/files/12245/frame_image.svg" alt="link" width="32" height="32" /> image with a text-top alignment.</div>
    
    <div>An <img class="bottom" src="https://mdn.mozillademos.org/files/12245/frame_image.svg" alt="link" width="32" height="32" /> image with a text-bottom alignment.</div>
    
    <div>An <img class="middle" src="https://mdn.mozillademos.org/files/12245/frame_image.svg" alt="link" width="32" height="32" /> image with a middle alignment.</div>
    
    An link image with a default alignment.
    An link image with a text-top alignment.
    An link image with a text-bottom alignment.
    An link image with a middle alignment.
  • 相关阅读:
    C++中合并两个排行榜的思路
    C++函数类型以及函数表实验
    C++获取两个值的差距比
    windows下的bash工具:winbash
    导入sql文件提示2006错误的解决办法
    C++延迟delete对象方案:采用unique_ptr托管欲删除的对象指针
    C++使用lower_bound快速查询分段配置
    sqlserver数据库操作
    判断 iframe 是否加载完成的完美方法
    SQL数据缓存依赖 [SqlServer | Cache | SqlCacheDependency ]
  • 原文地址:https://www.cnblogs.com/shih/p/7286401.html
Copyright © 2020-2023  润新知