• 豌豆资源网
  • 开引网企业服务
  • 服务外包网
  • css中vertical-aling与line-height

    基线

    baseline:字符x的底部

    x-height: 字母x的高度,vertical-aling设置为middle的时候,对齐的是baseline往上1/2的x-height,所以vertical-aling设置为middle不是整正的居中对齐

     

    line-height

    1.内容高度

    思考:未设置height的时候,可视高度由什么决定?

    .box {
        line-height: 0;
    }
    .box1 {
        line-height: 12px;
    }
    .box2 {
        line-height: 12px;
      font-size: 0;
    }
    <div class="box">
      内容内容
    </div>

    元素的高度是由line-height撑起来

    思考:对于非替换元素,line-height会影响元素高度吗?

    .box {
        line-height: 0;
    }
    .box1 {
        line-height: 120px;
    }
    <div class="box">
         <img src=''>
    </div>

    2.行距

    两行文字之间的间隙

    3.line-height属性值

    normal:

    默认是normal,与字体、浏览器有关,在1.2左右

    长度值:

    带单位的,直接按照这个值进行计算

    数值

    最终的计算值是和当前 font-size 相乘后的值

    百分比:

    最终的计算值是和当前 font-size 相乘后的值。

    父元素设置了百分比,子元素继承的不是百分比,而是父元素计算后的值

     

    vertical-align

    只能应用于内联元 素以及 display 值为 table-cell 的元素。

    1.baseline

    基线对齐

    2.数值

    相对基线上下移动

     

    问题

    1.不同字号文字在一起时,内容高度

    box { 
      line-height: 32px; 
    }
    .box > span { 
      font-size: 24px;
    }
    <div class="box">
        x<span>文字x</span>
    </div>

    文字默认是基线对齐,不同大小文字的基线对齐的时候,会发生上下唯一,如果唯一距离够大,就会产生意料之外的高度

    2.思考:box高度是多少

    .box { 
      line-height: 32px; 
    }
    .box > span { 
      font-size: 24px; 
    }
    <div class="box">
     <span>文字</span>
    </div> 

    结果:会比32px大一些

    这是因为在 HTML5 文档模式下,每一个“行框盒 子”的前面都有一个宽度为0的空白节点 - 幽灵空白元素,内联特性表现和普通字符相同

    等同于如下:


    由于空白节点的字体大小和元素内字体大小不同,导致发生位移,使元素高度撑高

    幽灵空白节点还会带来很多问题

    如图片高度问题:

    块级元素高度总是会比图片高度大一些,这是因为存在幽灵空白元素,由于vertical-aling默认是baseline,导致空白元素撑高了块级元素。

    posted @ 2020-05-10 16:21  前端一点红  阅读(170)  评论(0编辑  收藏  举报
  • 乐游资源网
  • 热爱资源网
  • 灵活用工代发薪平台
  • 企服知识
  • 355软件知识