CSS定位
元素的定位属性
静态定位(static)
相对定位relative(自恋型)
绝对定位absolute (拼爹型)
固定定位fixed(认死理型)
元素的显示与隐藏
元素的定位属性
选择器{position:属性值;}
position属性的常用值:
- static:自动定位
- relative:相对定位,相对于其原文档流的位置进行定位
- absolute:绝对定位,相对于其上一个已经定位的父元素进行定位
- fixed:固定定位,相对于浏览器窗口进行定位
静态定位(static)
静态定位是所有元素的默认定位方式,当position属性的取值为static时,可以将元素定位于静态位置。 所谓静态位置就是各个元素在HTML文档流中默认的位置。
在静态定位状态下,无法通过边偏移属性(top、bottom、left或right)来改变元素的位置。
相对定位relative(自恋型)
相对定位是将元素相对于它在标准流中的位置进行定位,当position属性的取值为relative时,可以将元素定位于相对位置。
相对定位最重要的一点是,它可以通过边偏移移动位置,但是原来的所占的位置,继续占有。
绝对定位absolute (拼爹型)
当position属性的取值为absolute时,可以将元素的定位模式设置为绝对定位。
父级没有定位
若所有父元素都没有定位,以浏览器为准对齐(document文档)。
父级有定位
绝对定位是将元素依据最近的已经定位(绝对、固定或相对定位)的父元素(祖先)进行定位。
绝对定位的盒子没有边偏移
如果只是给盒子指定了 定位,但是没有给与边偏移,则改盒子以标准流来显示排序,和上一个盒子的底边对齐,但是不占有位置。
子绝父相
子级是绝对定位的话, 父级要用相对定位。
因为子级是绝对定位,不会占有位置, 可以放到父盒子里面的任何一个地方。
父盒子布局时,需要占有位置,因此父亲只能是 相对定位。
固定定位fixed(认死理型)
固定定位是绝对定位的一种特殊形式,它以浏览器窗口作为参照物来定义网页元素。当position属性的取值为fixed时,即可将元素的定位模式设置为固定定位。
固定定位的特点:
- 固定定位的元素跟父亲没有任何关系,只认浏览器。
- 固定定位完全脱标,不占有位置,不随着滚动条滚动。
叠放次序(z-index)
当对多个元素同时设置定位时,定位元素之间有可能会发生重叠。
在CSS中,要想调整重叠定位元素的堆叠顺序,可以对定位元素应用z-index层叠等级属性,其取值可为正整数、负整数和0。如:z-index: 2;
注:
- z-index的默认属性值是0,取值越大,定位元素在层叠元素中越居上。
- 如果取值相同,则根据书写顺序,后来居上。
- 后面数字一定不能加单位。
- 只有相对定位,绝对定位,固定定位有此属性,其余标准流,浮动,静态定位都无此属性,亦不可指定此属性。
总结:
- 静态static:不脱标,正常模式,不可以使用边偏移,正常模式。
- 相对定位relative:不脱标,占有位置,可以使用边偏移,相对自身位置移动。
- 绝对定位absolute:完全脱标,不占有位置,可以使用边偏移,相对于定位父级移动位置。
- 固定定位fixed :完全脱标,不占有位置,可以使用边偏移,相对于浏览器移动位置。
元素的显示与隐藏
- display 显示
display : none 隐藏对象 与它相反的是 display:block
特点: 隐藏之后,不再保留位置。
- visibility 可见性
设置或检索是否显示对象。
visible : 对象可视
hidden : 对象隐藏
特点: 隐藏之后,继续保留原有位置。(停职留薪) - overflow 溢出
检索或设置当对象的内容超过其指定高度及宽度时如何管理内容。
visible : 不剪切内容也不添加滚动条。
auto : 超出自动显示滚动条,不超出不显示滚动条。
hidden : 不显示超过对象尺寸的内容,超出的部分隐藏掉。
scroll : 不管超出内容否,总是显示滚动条。