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
第三种方法(无副作用):
/*方法1*/
.clearfix{
*zoom:1;
}
.clearfix:after{
content:"";
display:block;
clear:left;
}
/*方法2*/
.clearfix{
*zoom:1;
}
.clearfix:after{
content:"";
display:table;
clear:both;
}
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轴(距离用户远近)上的顺序,值越大离用户越近、越在上层。
- z-index仅在设置了position非static属性的元素生效(适用于浮动元素),且z-index的值只能在兄弟元素之间比较。
- Z-index默认值为auto, 不建立层叠上下文。设置为0则会建立层叠上下文。
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不会重叠浮动元素。 http://js.jirengu.com/ruwut/1/edit?html,css,output
BFC可以包含浮动。 http://js.jirengu.com/zoqub/1/edit?html,css,output
7.在什么场景下会出现外边距合并?如何合并?如何不让相邻元素外边距合并?给个父子外边距合并的范例
按照BFC的定义, 只要同属于一个BFC, 两个元素才有可能发生垂直Margin的重叠, 这个包括相邻元素, 嵌套元素,只要他们之间没有阻挡(例如边框,非空内容,padding等)就会发生margin重叠
- 两个相邻的外边距都是正数时,折叠结果是它们两者之间较大的值
- 两个相邻的外边距都是负数时,折叠结果是两者绝对值的较大值
- 两个外边距一正一负时,折叠结果是两者的相加的和
一、阻止相邻元素外边距合并的方法是给相邻元素添加一个外壳, 是两个相邻元素不在同一个BFC中.
二、要阻止父子外边距合并, 可以让父元素形成BFC
具体参考文档
代码一:http://js.jirengu.com/buzeyuluto/1/edit?html,css,output
代码二:http://js.jirengu.com/bokafenihe/2/edit?html,output
代码三:http://js.jirengu.com/sosijapiqe/2/edit?html,css
代码四:http://js.jirengu.com/zumuseqaki/1/edit?html,css,output