深入理解CSS的盒子模型

作者: softbone | 来源:发表于2017-08-10 21:38 被阅读92次

1.1 块级盒子

块级盒子单独占据一行。块级盒子的高度和宽度为:width+padding+border。为其设置background-color,border也会变色。
width默认值为100%,和auto的变现效果是一样的,即为父元素的宽度,此时水平方向margin会为0。水平margin会自动变化来让盒子占据一行的空间。width为定值时:margin :10px auto (上下的margin随便设置)让盒子水平居中。垂直方向的margin不会自动补全。 块级盒子与盒子之间的间距(margin)是可以合并的,取其中的大值。

1.2 行级盒子

1.2.1 看得到的行级盒子

display为inline 、inline block的都是行级盒子。input 、textarea 、img 、button标签生成元素的默认也是inline block。

1.2.2 看不到的“盒子”

1.匿名文本

匿名文本(anonymous text)是指所有未包含在任何标签里的字符串。利用匿名文本能很快确定行框baseline和middleline。具体的戳着 确定行框的baseline

2.em框

em框在字体中定义,也称为字符框(character box)。实际的字形可能比其em框更高或更矮。在CSS中,font-size的值确定了各个em框的高度

在chrome中可以验证,选中文字,出现的蓝色块就是em框(我是这么理解的)。该蓝色盒子我称为字体盒子,它的高度的宽度只能font-size有关,而且高度大概一直是font-size的1.3倍。(自己可以去试试)

3.行内框(inline box)

相对于替换元素来说(像input img textarea 和自定义的inline-block)行内框的高度等于元素设置的height+padding+border+margin(这里和块级盒子有所不同)。(自定义的inline-block如果没指定高度则其高度是受line-height影响的)
对于非替换元素,元素行内框的高度等于line-height的高度,像span,i,a 这些。注意有的时候line-height是可能比字体盒子(em框)的高度要小的,这种情况下,行内框的高度还是和line-height保持一致,字体盒子的垂直中线和line-height的重合。

4.行框(line box)

行框是包含该行中出现的行内框的最高点和最低点的最小框。换句话说,行框的上边界要位于位置最高行内框的上边界;而行框的底边要放在位置最低行内框的下边界。

对于没指定高度的块级元素,其高度就是由一个个行框堆起来的。

对于怎么确定行框的高度,需要结合vertical-align 、line-height、font-size这三个属性确定。
在进行行内元素布局时,每个inline box会根据自己的vertical-align去找参照物对齐。然后计算最高的inline box的顶部和最低的inline box的底部间的距离。
vertical-align默认的是baseline 即元素的基线与所在行框的基线对齐,点这 确定行框的baseline
感谢:
理解CSS视觉格式化

相关文章

  • 2019-06-24

    转 一、html和css部分 1、如何理解CSS的盒子模型? 标准盒子模型:宽度=内容的宽度(content)+ ...

  • 2019前端基础面试秘籍

    一、html和css部分1、如何理解CSS的盒子模型?标准盒子模型:宽度=内容的宽度(content)+ bord...

  • 2019前端基础面试秘籍

    一、html和css部分 1、如何理解CSS的盒子模型? 标准盒子模型:宽度=内容的宽度(content)+ bo...

  • CSS 盒子模型

    CSS盒子模型 盒子模型边框 CSS盒子模型的宽度和高度 CSS模型的填充 CSS盒子模型的边界 填充和边界的区别

  • 深入理解CSS的盒子模型

    1.1 块级盒子 块级盒子单独占据一行。块级盒子的高度和宽度为:width+padding+border。为其设置...

  • 2019-05-05

    基于CSS盒子模型及其CSS定位详解 CSS盒子模型 效果显示 盒子模型的简单应用 效果显示: CSS定位 效果显示

  • 理解css盒模型

    盒子模型是CSS中一个重要概念,理解了盒子模型才能更好的排版。盒子模型分为两种:ie盒子模型(怪异盒模型)和标准w...

  • 前端CSS概念&技巧

    1、如何理解CSS的盒子模型? 每个HTML元素都是长方形盒子。 (1)盒子模型有两种:IE盒子模型、标准W3C盒...

  • css基础问题

    介绍css的盒子模型 css的盒子模型有两种:IE盒子模型,W3C盒子模型盒子模型:内容(content),内边距...

  • CSS盒模型

    盒子模型是CSS中一个重要的概念,理解了盒子模型才能更好的排版和布局。盒子模型有两种,分别是 IE 盒子模型和标准...

网友评论

    本文标题:深入理解CSS的盒子模型

    本文链接:https://www.haomeiwen.com/subject/rsckrxtx.html