浮动、定位、BFC、边距合并

浮动元素有什么特征?对父容器、其他浮动元素、普通元素、文字分别有什么影响?

  1. 特征:
  • 脱离正常文档流,沿其容器的左侧或右侧放置,外边缘碰到包含框或另一浮动元素的边缘时会停下,文本和内联元素将环绕它。
  • float的计算值不为none。
  • float意味着使用块布局,所以某些情况下可以修改display的计算值,如给inline元素或inline-block设置float属性,其display属性就被隐性设置为block。
  • 提升层次半级。
  1. 影响:
  • 对父容器:元素浮动后脱离正常文档流,导致无法撑开父元素,造成父元素高度塌陷,除非给父元素也设置浮动或overflow属性。
  • 对其他浮动元素:浮动元素会紧贴同一方向上其他浮动元素排列,父元素宽度不够的情况下会换行;反方向的浮动元素位于同一水平线上分别浮动、互不影响,但空间不够时也会被挤下,被迫换行。
  • 对普通元素:浮动元素虽和绝对定位元素有所差别,但同样是脱离了正常文档流,普通元素察觉不到其存在,会占用它原本的空间。
  • 对文字:文字环绕浮动元素。

清除浮动指什么? 如何清除浮动? 两种以上方法

  1. 清除浮动:元素浮动之前在标准流中纵向排列,浮动之后可以理解为横向排列,所以清除浮动可以理解为打破横向排列。

  2. 如何清除:

  • clear:both|left|right:分别表示元素被向下移动用于清除之前的所有/左/右浮动,适用于浮动和非浮动元素。
    举个例子:
    比如页面中只有两个元素div1和div2,都是左浮动,父元素宽度足够的情况下,div2会跟随在div1后面。

但我们希望div2能够排列在div1下面,就像div1没有浮动而div2左浮动一样,这时就要用到清除浮动,我们应在div2中设置"clear: left;"来指定div2左边不允许出现浮动元素,这样div2就被迫下移一行。

结论:clear规则只影响使用清除的元素本身,不能影响其他元素

  • overflow: hidden/auto;:不存在结构化和语义化问题,代码量少,但内容增多时可能会导致内容隐藏,无法显示需要溢出的内容。

  • 浮动元素的父元素也设置浮动:下面的BFC一题中有举例。

  • 浮动元素的父元素设置display:table;:改变了盒模型属性所以可能会造成一系列问题。

  • 使用::after伪元素:结构和语义化完全正确、代码量居中,但复用方式造成代码量增加。
    注意:使用伪元素时一定要有content属性,使用伪元素清除浮动,除了要有clear属性外,还要记住,伪类元素默认display:inline-block;把值设为block更为稳妥!!!

有几种定位方式,分别是如何实现定位的,参考点是什么,使用场景是什么?

三种定位方式:普通流、position定位、浮动。默认普通流。

  • 普通流定位:
    块级框从上到下一个接一个地排列,框之间的垂直距离是由框的垂直margin计算出来(margin合并)。
    由一行形成的水平框称为行框(Line Box),行框的高度总是足以容纳它包含的所有行内框。
    行内框在一行中水平布置。可以使用水平padding、border和margin调整它们的间距。但是,垂直内边距、边框和外边距不影响行内框的高度。
  • position定位:值:static|relative|absolute|fixed;
    static默认没有定位;
    relative相对于自身正常位置左上角定位,定义元素框偏移某个距离,这个距离可以为负值。在使用相对定位时,无论是否进行移动,元素仍然占据原来的空间,因此移动元素会导致它覆盖其它框。相对定位一般用于需要绝对定位的子元素的父元素中。
    absolute绝对定位,相对于static定位以外最近的已定位的祖先元素,如果没有已定位的祖先元素,那么它的位置相对于最初的包含块。如果设置了absolute但没有设置值,那么使用了absolute的元素在页面中的位置不会改变,但已经脱离了文档流,与普通流已不在一个index-z层面上,因此不占据空间,其他元素表现得就好像该元素不存在一样,元素定位后生成一个块级框,而不论原来它在正常流中是何种类型的框。比如需要一个元素水平垂直居中就会用到absolute。
    fixed相对于浏览器窗口固定定位,元素的margin角点相对于整个窗口定位,可以把fixed看作是absolute的特殊情况。定位之后的元素A在显示页面上可能会覆盖原本在此位置上的普通流元素B,A有多大就覆盖多达面积。比如有些块框需要固定在页面上方就可以用fixed。
  • float浮动定位:值:none|left|right;
    值不为none的情况下,浮动定位与绝对定位一样会脱离正常文档流,沿其容器的左侧或右侧放置,外边缘碰到包含框或另一浮动元素的边缘时会停下,普通元素察觉不到浮动元素存在会占用它原本的空间,文本和内联元素将环绕它。比如需要做一个有按钮的导航栏就可以用到浮动。

z-index 有什么作用? 如何使用?

  1. 作用:
    z-index属性设置元素的堆叠顺序。该属性设置一个定位元素沿z轴的位置,z轴定义为垂直延伸到显示区的轴。
  2. 使用:
    z-index的值默认为auto,即堆叠顺序继承自父元素,不建立层叠上下文,值为0则建立层叠上下文,也可设置值为number,number值可以为负数。如果为正数,则离用户更近,为负数则表示离用户更远,值越大越靠近用户,当元素的层叠水平一致、层叠顺序相同时,在DOM流处于后面的元素会覆盖前面的元素。
    注意:z-index只能在值不为static的定位元素上奏效(例如 position:absolute;),且值只能在兄弟元素间进行比较。

position:relative和负margin都可以使元素位置发生偏移,二者有什么区别?

  • relative是相对定位,还在正常文档流中,无论元素是否进行移动它都仍占据原来的空间,也就是说其他的元素的位置不会发生改变。移动元素可能会覆盖其他的框,因为它的z-index层级发生了改变,可理解为只会重绘,不会回流。
  • 负margin会影响文档中其他元素的位置,造成页面的回流与重绘。

BFC 是什么?如何生成 BFC?BFC 有什么作用?举例说明。

  1. BFC——block formatting context:块格式化上下文,是Web页面的可视化CSS渲染的一部分,是块盒子的布局发生、浮动、互相交互的区域。通俗理解,首先BFC是一个独立的布局环境,我们可以理解为一个箱子(实际上是看不见摸不着的),箱子里面物品的摆放是不受外界的影响的,反之也如此。

  2. 如何生成:一个块格式化上下文由以下之一创建:

  • 根元素或其它包含它的元素
  • 浮动(元素的 float不是 none)
  • 绝对定位的元素(元素的position为 absolute或 fixed)
  • 内联块 inline-blocks (元素具有display: inline-block)
  • 表格单元格 (元素具有display: table-cell,HTML表格单元格默认属性)
  • 表格标题 (元素具有 [display: table-caption, HTML表格标题默认属性)
  • 块元素具有overflow ,且值不是 visible
  • display:flow-root
  1. 作用:
  • 自适应两栏布局:
    设置浮动使元素脱离正常文档里,生成BFC,与normal状态下的元素互不影响,由此形成自适应两栏布局。
  • 防止垂直方向上的margin合并:
    设置了绝对定位的p生成了一个BFC,与其他两个p不属于同一个BFC,不会发生margin合并。
  • 清除浮动,防止内部塌陷
    子元素设置了浮动脱离了正常文档流,那么其父元素也要设置浮动或者overflow属性来生成BFC去包裹子元素,才不会造成高度塌陷。

在什么场景下会出现外边距合并?如何合并?如何不让相邻元素外边距合并?给个父子外边距合并的范例。

1、 概念
块的顶部外边距和底部外边距有时被组合(折叠)为单个外边距,其大小是组合到其中的最大外边距,这种行为称为外边距塌陷(margin collapsing),有的地方翻译为外边距合并。

2、 合并场景及如何合并——垂直方向上合并。

  • 相邻的兄弟元素(除非后一个兄弟元素的出现是为了清除浮动):兄元素的下外边距和弟元素的上外边距挨到了一起就会发生外边距合并,合并之后的外边距不是兄-下外边距与弟-上外边距之和,而是两者间较大的那个,可以理解为取并集。

  • 块级父元素与其第一/最后一个子元素:当块级父元素中不存在上边框、上内边距、內联元素、清除浮动这四条属性时,此块级父元素会与其第一个子元素发生上外边距合并,此时父元素对外展现出来的上外边距将直接变成这个父元素和其第一个子元素的margin-top较大者;类似的,若块级父元素的 margin-bottom 与它的最后一个子元素的margin-bottom之间没有父元素的 border、padding、inline content、height、min-height、max-height分隔时,就会发生下外边距合并现象。

  • 空块元素:如果存在一个空的块级元素,其 border、padding、inline content、height、min-height 都不存在。那么此时它的上下边距中间将没有任何阻隔,此时它的上下外边距将会合并,即自身合并。

元素按照以上规则发生合并,即使外边距为0,这些规则也仍旧生效。因此,无论父元素的外边距是否为0,第一个或者最后一个子元素的外边距会被父元素的外边距"截断",在负外边距的情况下,合并后的外边距为最大正外边距与最小负外边距之和。这就是一系列段落元素占用空间非常小的原因。

3、 外边距合并规则:

  • 两个margin都是正值的时候,取两者的最大值;
  • 当 margin 都是负值的时候,取的是其中绝对值较大的,然后,从0位置,负向位移;
  • 当有正有负的时候,先取出负 margin 中绝对值中最大的,然后,和正 margin 值中最大的 margin 相加。
  • 所有响铃的margin要一起参与运算,不能分步进行。

4、 阻止相邻元素外边距合并:BFC-块格式化上下文——会阻止元素外边距合并,如把元素设置为浮动和绝对定位那么它的外边距不会发生合并。

5、 父子外边距合并示例:

<style>
        .dad {
            background: red;
            width: 200px;
            height: 200px;
            margin: 20px;
        }
        .son {
            background: yellow;
            width: 100px;
            height: 100px;
            margin: 30px;
        }
</style>
<div class="dad">
    <div class="son"></div>
</div>

代码

代码1
代码2
代码3
代码4

参考资料

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,560评论 4 361
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,104评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,297评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,869评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,275评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,563评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,833评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,543评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,245评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,512评论 2 244
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,011评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,359评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,006评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,062评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,825评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,590评论 2 273
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,501评论 2 268

推荐阅读更多精彩内容