美文网首页
浮动定位BFC边距合并

浮动定位BFC边距合并

作者: 顺丰笑嘻嘻 | 来源:发表于2017-09-07 10:24 被阅读0次

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

浮动元素特征:浮动元素不在文档的普通流中,文档的普通流中的元素表现的就像浮动元素不存在一样。

  • 对父容器:如果未设定高度的父容器下都是浮动元素,则父容器失去高度。
  • 对其他浮动元素:如果包含块儿太窄无法容纳水平排列的三个浮动元素,那么其它浮动块儿向下移动,直到有足够的空间,如果浮动元素的高度不同,那么向下移动的时候可能被卡住
  • 对普通元素:普通元素无法感知浮动元素的存在,会占据原来浮动元素的位置,但会被浮动元素遮盖。
  • 对文字:文字会感知浮动元素的存在,会移动以留出空间 ,在浮动元素周围进行环绕。

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

清除浮动指解决浮动父容器高度塌陷问题,减少浮动带来的影响。
清除浮动的方法:

  1. 在浮动元素最后再加个空div,并用clear属性进行清除,属性对应有:both left right none表示框的哪边不挨着浮动框。缺点是增加了一个无意义的标签。
  2. 用BFC清理浮动
  • float为 left|right
  • overflow为 hidden|auto|scroll
  • display为 table-cell|table-caption|inline-block
  • position为 absolute|fixed
    低版本IE,当元素的hasLayout属性值为true的时候会达到和BFC类似的效果,元素负责本身及其子元素的尺寸设置和定位。

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

  1. inherit:规定应该从父元素继承 position 属性的值
  2. static:默认值,没有定位,元素出现在正常的流中(忽略 top, bottom, left, right 或者 z-index 声明)
  3. relative:生成相对定位的元素,相对于元素本身正常位置进行定位。使用场景:为绝对定位设定参照物或对元素自身位置进行局部调整。
  4. absolute:生成绝对定位的元素,相对于static定位以外的第一个祖先元素(offset parent)进行定位,元素的位置通过 left, top, right 以及 bottom 属性进行规定。使用场景:当想让元素参照特定参照物进行定位时使用。
  5. fixed:定定位,固定定位是绝对定位的一种,固定定位的元素也不包含在普通文档流中,差异是固定元素的包含块儿是视口(viewport)

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

z-index 属性设置元素的堆叠顺序。拥有更高堆叠顺序的元素总是会处于堆叠顺序较低的元素的前面。
注释:元素可拥有负的 z-index 属性值。
注释:Z-index 仅能在定位元素上奏效(例如 position:absolute;)!


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

position:relative只相对自己原本位置发生偏移,不影响其它普通流中元素的位置。
margin除了让元素自身发生偏移还影响其它普通流中的元素。


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

BFC是块级格式化上下文(Block Formatting Context)。
至少满足下列条件之一才能形成BFC:

  • float属性不为none.
  • position属性不为static和relative.
  • display属性为下列之一:table-cell,table-caption,inline-block,flex,或者 inline-flex.
  • overflow属性不为visible.
    BFC作用:
  1. BFC会阻止垂直外边距(margin-top、margin-bottom)折叠。
  2. BFC不会重叠浮动元素。
  3. BFC可以包含浮动。

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

在同一个BFC中,相邻元素之间的外边距会合并,加入分别给两个元素设置同样的外边距,一般会发生重叠,只显示一个元素的外边距大小。若相邻元素外边距为一正一负,则为两边距相加的结果;若同为负则显示绝对值较大的边距。若想要时边距不合并,可以把两个元素分别放到不同的BFC中,即在后面的元素构建一个新的BFC。
范例如下:

.box {
  background: grey;
}

.box1 {
  width: 100px;
  height: 100px;
  background: red;
  margin: 20px;
}

.box2 {
  width: 100px;
  height: 100px;
  background: green;
  margin: 20px;
}
image.png

父子元素外边距合并;

.box {
  background: grey;
  overflow: hidden;
}

.box1 {
  width: 100px;
  height: 100px;
  background: red;
  margin: 20px;
}

.box2 {
  width: 100px;
  height: 100px;
  background: green;
  margin: 20px;
}
image.png

取消父子外边距合并。

相关文章

  • 浮动定位BFC边距合并

    1.浮动元素有什么特征?对父容器、其他浮动元素、普通元素、文字分别有什么影响? 浮动模型也是一种可视化模型,浮动的...

  • 浮动定位BFC边距合并

    1.浮动元素有什么特征?对父容器、其他浮动元素、普通元素、文字分别有什么影响? 浮动元素会脱离普通文档流,直到碰到...

  • 浮动定位BFC边距合并

    浮动元素有什么特征?对父容器、其他浮动元素、普通元素、文字分别有什么影响? 浮动元素也是一种可视化格式模型,浮动的...

  • 浮动定位BFC边距合并

    1.浮动元素有什么特征?对父容器、其他浮动元素、普通元素、文字分别有什么影响? 浮动元素的特征:首先脱离文档正常流...

  • 浮动定位BFC边距合并

    1. 浮动元素的特征,对其他浮动元素、普通元素、文字的影响 浮动模型是一种可视化格式模型,浮动元素可以左右移动(根...

  • 浮动定位BFC边距合并

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

  • 浮动定位BFC边距合并

    浮动元素有什么特征?对父容器、其他浮动元素、普通元素、文字分别有什么影响? 浮动的元素会脱离文档流.向左或者向右移...

  • 浮动定位BFC边距合并

    1.浮动元素有什么特征?对父容器、其他浮动元素、普通元素、文字分别有什么影响? 浮动元素会脱离标准的文档流,浮动的...

  • 浮动定位BFC边距合并

    1.浮动元素有什么特征?对父容器、其他浮动元素、普通元素、文字分别有什么影响? 浮动元素不在文档的普通流中,它可以...

  • 浮动定位BFC边距合并

    浮动元素有什么特征?对父容器、其他浮动元素、普通元素、文字分别有什么影响? 浮动元素使一个元素脱离正常的文档流,然...

网友评论

      本文标题:浮动定位BFC边距合并

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