1.浮动元素有什么特征?对父容器、其他浮动元素、普通元素、文字分别有什么影响?
浮动元素特征:浮动元素不在文档的普通流中,文档的普通流中的元素表现的就像浮动元素不存在一样。
- 对父容器:如果未设定高度的父容器下都是浮动元素,则父容器失去高度。
- 对其他浮动元素:如果包含块儿太窄无法容纳水平排列的三个浮动元素,那么其它浮动块儿向下移动,直到有足够的空间,如果浮动元素的高度不同,那么向下移动的时候可能被卡住
- 对普通元素:普通元素无法感知浮动元素的存在,会占据原来浮动元素的位置,但会被浮动元素遮盖。
- 对文字:文字会感知浮动元素的存在,会移动以留出空间 ,在浮动元素周围进行环绕。
2.清除浮动指什么? 如何清除浮动? 两种以上方法
清除浮动指解决浮动父容器高度塌陷问题,减少浮动带来的影响。
清除浮动的方法:
- 在浮动元素最后再加个空div,并用clear属性进行清除,属性对应有:both left right none表示框的哪边不挨着浮动框。缺点是增加了一个无意义的标签。
- 用BFC清理浮动
- float为 left|right
- overflow为 hidden|auto|scroll
- display为 table-cell|table-caption|inline-block
- position为 absolute|fixed
低版本IE,当元素的hasLayout属性值为true的时候会达到和BFC类似的效果,元素负责本身及其子元素的尺寸设置和定位。
3.有几种定位方式,分别是如何实现定位的,参考点是什么,使用场景是什么?
- inherit:规定应该从父元素继承 position 属性的值
- static:默认值,没有定位,元素出现在正常的流中(忽略 top, bottom, left, right 或者 z-index 声明)
- relative:生成相对定位的元素,相对于元素本身正常位置进行定位。使用场景:为绝对定位设定参照物或对元素自身位置进行局部调整。
- absolute:生成绝对定位的元素,相对于static定位以外的第一个祖先元素(offset parent)进行定位,元素的位置通过 left, top, right 以及 bottom 属性进行规定。使用场景:当想让元素参照特定参照物进行定位时使用。
- 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作用:
- BFC会阻止垂直外边距(margin-top、margin-bottom)折叠。
- BFC不会重叠浮动元素。
- 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
取消父子外边距合并。
网友评论