1. 文档流的概念指什么?有哪种方式可以让元素脱离文档流?
文档流是文档中可显示对象在排列时所占用的位置。比如网页的div标签它默认占用的宽度位置是一整行,p标签默认占用宽度也是一整行,因为div标签和p标签是块状对象。 网页中大部分对象默认是占用文档流,也有一些对象是不占文档流的,比如表单中隐藏域。
浮动和定位可以是元素脱离文档流:
浮动:通过设置float属性
定位:通过设置position属性来控制。绝对定位:position:absolute/固定定位:position:fixed
2. 有几种定位方式,分别是如何实现定位的,使用场景如何?
CSS 定位 (Positioning) 属性允许你对元素进行定位。定位的基本思想很简单,它允许你定义元素框相对于其正常位置应该出现的位置,或者相对于父元素、另一个元素甚至浏览器窗口本身的位置。
值 | 属性 | 使用场景 |
---|---|---|
static | 默认值。没有定位,元素出现在正常的流中(忽略top,bottom,left,right或者z-index申明) | 默认值不设置。 |
relative | 生成相对定位的元素,相对于其正常位置进行定位。占用空间,相当于原元素的位置移动,不会脱离文档流。如:left:20px会向元素的left位置添加20像素。 | 其它元素定位时需要把它自身作为参考点。 |
absolute | 生成绝对定位的元素,相对于static定位以外的第一个父元素进行定位。元素的位置通过left,top,right以及bottom属性进行规定,会脱离文档流。 | 元素定位时把父元素作为参考点。 |
fixed | 生成绝对定位的元素,相对于浏览器窗口进行定位。元素的位置通过left,top,right以及bottom属性进行规定。 | 广告窗口或底部菜单,用于固定位置显示的地方。 |
3. absolute, relative, fixed 偏移的参考点分别是什么?
absolute的参考点是离最近的元素position设置fixed、relative的父级或者祖先元素,如果父元素没有,则一层一层往上找,最终到body元素。
relative的参考点是其原来自身的位置。
fixed的参考点是浏览器的窗口。
4. z-index 有什么作用? 如何使用?
z-index属性设置元素的堆叠顺序。拥有更高堆叠顺序的元素总是会处于堆叠顺序较低的元素的前面。
z-index只有在使用了定位属性(即position且值为relative\absolute\fixed)的元素上才可使用;有较高z-index值的元素比z-index值较低的元素离读者更近;z-index的值是正负整数。
5. position:relative和负margin都可以使元素位置发生偏移?二者有什么区别?
position:relative使元素偏移时,仅仅只是自身位置发生偏移,并不影响其他元素的布局。
margin设置负值是元素偏移时,不但改变了元素本身,而且还改变了周围其他元素的布局。
6. 如何让一个固定宽高的元素在页面上垂直水平居中?
首先将position值设置为absolute,让元素脱离文档流,然后设置top和left为50%,让元素的左上角位于页面中点,最后通过设置margin为负值使元素在页面上垂直水平居中。
7. 浮动元素有什么特征?对其他浮动元素、普通元素、文字分别有什么影响?
特征:
- 浮动会让元素脱离文档流
- 浮动的框可以向左或向右移动,直到它的外边缘碰到包含框或另一个浮动框的边框为止
- 浮动元素不会互相重叠
- 如果没有足够的空间,浮动元素会被挤到新的一行
影响:
- 其他浮动元素:浮动元素会依次排在其之前浮动元素左边或右边,直到其父元素不能放下,将会被挤到新的一行。
- 普通元素:浮动元素会浮在页面上,后面的普通元素将会占据其原来的位置
- 文字:文字会围绕着浮动元素
8.清除浮动指什么? 如何清除浮动?
清除浮动是指解除浮动带来的负面影响,比如由于浮动,父元素无法撑起高度,影响与父元素同级的元素;与浮动元素同级的非浮动元素会紧随其后;若非第一个元素浮动,则该元素之前的元素也需要浮动,否则会影响页面显示结构。
如何清除浮动可以通过clear属性来清除浮动,CSS中的属性是 clear:left | right | both | none;一定要牢记:这个规则只能影响使用清除的元素本身,不能影响其他元素。