博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
css中的IFC
阅读量:4137 次
发布时间:2019-05-25

本文共 2064 字,大约阅读时间需要 6 分钟。

IFC(Inline Formatting Contexts)

意为“内联格式化上下文”,IFC中,盒子依次水平放置,从包含块的顶部开始。

IFC布局规则:

1.框会从包含块的顶部开始,一个接一个地水平摆放。

2.摆放这些框的时候,它们在水平方向上的外边距、边框、内边距所占用的空间都会被考虑在内。在垂直方向
上,这些框可能会以不同形式来对齐:它们可能会把底部或顶部对齐,也可能把其内部的文本基线对齐。能
把在一行上的框都完全包含进去的一个矩形区域,被称为该行的行框。水平的margin、padding、border有
效,垂直无效。不能指定宽高。
3.行框的宽度是由包含块和存在的浮动来决定。行框的高度由行高计算这一章所描述的规则来决定。

结论:

1 一个line box总是足够高对于包含在它内的所有盒子。然后,它也许比包含在它内最高的盒子高。(比如,盒子对齐导致基线提高了)。

2.当盒子B的高度比包含它的line box的高度低,在line box内的B的垂值对齐线通过’vertical align’属性决定。当几个行内级盒子在一个单独的line box内不能很好的水平放置,则他们被分配成了2个或者更多的垂直重叠的line boxs.因此,一个段落是很多个line boxs的垂直叠加。Line boxs被叠加没有垂直方向上的分离(特殊情况除外),并且他们也不重叠。
3.通常,line box的左边缘挨着它的包含块的左边缘,右边缘挨着它的包含块的右边缘。然而,浮动盒子也许会在包含块边缘和line box边缘之间。因此,尽管line boxs在同样的行内格式上下文中通常都有相同的宽度(就是他的包含块的宽度),但是水平方向上的空间因为浮动被减少了,它的宽度也会变得复杂。Line boxs在同样的行内格式上下文中通常在高度上是多样的(比如,一行也许包含了一个最高的图片然后其他的也可以仅仅只包含文字)
4.当在一行中行内级盒子的总宽度比包含他们的line box的宽度小,他们的在line box中的水平放置位置由’text align’属性决定。如果属性是’justify’,用户代理可能会拉伸空间和文字在inline boxs内。
5.当一个行内盒子超过了line box的宽度,则它被分割成几个盒子并且这些盒子被分配成几个横穿过的line boxs。如果一个行内盒子不能被分割。则行内盒子溢出line box。
6.当一个行内盒子被分割,分割发生则margins,borders,和padding便没有了视觉效果。
7.在同样的line box内的行内盒子也许会被分割成几个盒子因为双向的文字。
Line boxs在行内格式上下文中档需要包含行内级内容时被创造。Line boxs包含没有文字,没有空格,没有带着margins,padding和borders,以及没有其他在流中的内容(比如图片,行内盒子和行内表格),也不会以新起一行结尾。对于在他们内的任何盒子的位置都以他们决定并且必须将他们视作没有高度的line boxs。

主要印象IFC内布局的CSS:
  • font-size
  • line-height
  • height
  • vertical-aligin
  1. line box
    行盒模型,这是一个显示区域,根据块状容器内,每一行的多个内联元素(inline-level element)都会共同生成一个行盒模型。
  2. font-size
    常见的属性,用来指定文本类型节点的大小。IFC内的很多属性的值是基于这个的。
  3. line-height & height
    在一个由多个内联元素组成的块状容器内,’line-height’为内联元素的行盒模型指定了一个最低高度。 这个最低高度是分别由基线上的最小高度和基线下的最小深度组成。
    从上到下四条线分别是顶线、中线、基线、底线。 那么行高是指上下文本行的基线间的垂直距离,即图中两条红线间垂直距离(实际在数值上,行高也等于其它相同颜色间的距离)。
    在这里插入图片描述
  4. vertical-align
    该属性影响由多个内联元素生成的盒模型组成的行内盒模型的垂直定位。 vertical有几个特定的值,
    或者指定一个值。
    <p class="a1">
    <span style="vertical-align:60px;">
    English中文
    </span>
    <span>
    中文English
    </span>
    </p>
    给第一个span,设置60px的垂直偏移量,显示如下:
    其中,黄色线就是基线(baseline),绿线和黄线的间隔即为60px。 这里会发现,容器(蓝色)的高度被撑高了。
    容器的高度 height = line-height + vertical-align
    当然同理,如果容器的高度被指定了,那么高度则不变,而超出的部分则不影响布局。如果设置overflow:hidden,超过的部分则不可见。
    而vertical-align的其它特殊值,均可以看做一个根据容器高度而变化的相对值。

转载地址:http://gvqvi.baihongyu.com/

你可能感兴趣的文章
流形学习-高维数据的降维与可视化
查看>>
Python-OpenCV人脸检测(代码)
查看>>
python+opencv之视频人脸识别
查看>>
人脸识别(OpenCV+Python)
查看>>
6个强大的AngularJS扩展应用
查看>>
网站用户登录系统设计——jsGen实现版
查看>>
第三方SDK:讯飞语音听写
查看>>
第三方SDK:JPush SDK Eclipse
查看>>
第三方开源库:imageLoader的使用
查看>>
自定义控件:飞入飞出的效果
查看>>
自定义控件:动态获取控件的高
查看>>
第三方开源库:nineoldandroid:ValueAnimator 动态设置textview的高
查看>>
第三方SDK:百度地图SDK的使用
查看>>
Android studio_迁移Eclipse项目到Android studio
查看>>
JavaScript setTimeout() clearTimeout() 方法
查看>>
CSS border 属性及用border画各种图形
查看>>
转载知乎-前端汇总资源
查看>>
JavaScript substr() 方法
查看>>
JavaScript slice() 方法
查看>>
JavaScript substring() 方法
查看>>