zoukankan      html  css  js  c++  java
  • vertical-align

    在了解vertical-align之前我们先了解基线:
    在了解基线之前我们先了解Inline Element,Inline-Block Element,Line Box
    Inline Element:内联元素
    Inline-Block Element:内联块状元素
    Line Box:由以上两点组成的一行

    基线:
    Inline Element的基线就是x的底部
    Inline-Block Element的基线默认是其内部单词的最后一个单词的底部,但是如果他是绝对定位,或者overflow:hidden 则他的基线就是margin-bottom的底部
    Line Box的高度默认是他内部最高处的元素的最上面和他内部最低处的元素的底部的距离,他的基线默认是很难看到的,但是我们依然可以想办法看到,在该行的最前面写上一个字母x,这个x的底部就是基线 同Inline Element元素一样(所以理论上我们可以通过line-height调整该元素的基线位置)

    所以设置内联元素的vertual-align本质上是设置内联元素的基线相对于Line Box基线的位置
    baseline: 元素的基线刚好放置在line box基线的上。
    sub: 元素的基线放置在line box基线的下面。
    super: 元素的基线放置在line box的基线的上面。
    middle:元素的顶部与底部边缘的中点相对于line box的基线移动x-height的一半的位置对齐。

    所以如果我们希望两个内联元素底部对齐,我们只需要将他们的基线设置为该行的基线就是baseline就可以了
    如果我们希望两个内联元素居中对齐呢?比如一个图片一个文字?
    我们首先让图片vertical-align: middle; 然后设置文字在span块内垂直居中,可以通过height: 40px; line-height: 40px; display: inline-block;来实现,然后也设置文字vertical-align: middle;

    一般我们有时候会设置某个元素的vertical-align,却发现其他元素的位置改变了,
    如果在一行中,有一个高的元素占据了整行的高度,vertical-align对它不会有任何影响。在它的顶部上面与底部下面没有任何多余的空间可以移动它。为了实现它相对于line box基线的对齐,line box的基线必须移动。其他针对于line box基线对齐的元素自然也会相应的改变位置

    参考:https://segmentfault.com/a/1190000007663895

    然而在不同浏览器上 vertual-align的表现并不一致,准确说某些属性并不一致,目前确定的是middle top bottom baseline是可以一致的.

  • 相关阅读:
    可扩展多线程异步Socket服务器框架EMTASS 2.0
    认识迅雷界面引擎
    C语言 二维数组(指针)动态分配和释放(转)
    二维数组与双重指针(转)
    VC++6 调用teststand api的方法
    [VC6] 小谈如何解决VC6.0 open崩溃的问题(已解决)(转)
    Linux下C与Mysql的混合编程(转)
    VS2010生成安装包制作步骤 (转)
    SAO总结
    JS OOP编程
  • 原文地址:https://www.cnblogs.com/mrzhu/p/11272555.html
Copyright © 2011-2022 走看看