学习要点:
1、相对定位
2、绝对定位
3、固定定位
4、z-index属性
一、相对定位
定义:相对定位就是相对于自己以前在标准流中的位置来移动
格式:{position:relative;} top left right bottom
注意: 1.相对定位是不脱离标准流的, 会继续在标准流中占用一份空间
2.在相对定位中同一个方向上的定位属性只能使用一个
3.在相对定位中是区分块级元素/行内元素/行内块级元素
4.当给相对定位的元素设置margin/padding等属性的时会影响到标准流的布局
二、绝对定位
定义:绝对定位就是相对于body来定位
格式:{position: absolute;} top left right bottom
注意: 1.绝对定位的元素是脱离标准流的
2.绝对定位的元素是不区分块级元素/行内元素/行内块级元素
3.如果一个绝对定位的元素是以body作为参考点, 那么其实是以网页首屏的宽度和高度作为参考点,
而不是以整个网页的宽度和高度作为参考点
4.一个绝对定位的元素会忽略祖先元素的padding
参考点:1.默认情况下所有的绝对定位的元素, 无论有没有祖先元素, 都会以body作为参考点
2.当一个绝对定位的元素有祖先元素(注意是祖先),
并且祖先元素也是定位流(只包含绝对定位/相对定位/固定定位),
那么这个绝对定位的元素就会以定位流的那个祖先元素作为参考点
3.当一个绝对定位的元素有祖先元素, 并且祖先元素也是定位流, 而且祖先元素中有多个元素都是定位流,
那么这个绝对定位的元素会以离它最近的那个定位流的祖先元素为参考点
子绝父相:子元素用绝对定位, 父元素用相对定位
让绝对定位的元素水平居中:
设置绝对定位元素的left:50%;
设置绝对定位元素的 margin-left: -元素宽度的一半px;
三、固定定位
定义:固定定位可以让某个盒子不随着滚动条的滚动而滚动,和背景关联方式很像。
格式:{position: fixed;} top buttom left right
注意:1.固定定位的元素是脱离标准流的, 不会占用标准流中的空间
2.固定定位和绝对定位一样不区分行内/块级/行内块级
3.IE6不支持固定定位
四、z-index属性
作用:z-index属性的作用是专门用于控制定位流元素的覆盖关系的
注意:默认情况下定位流的元素会盖住标准流的元素
默认情况下定位流的元素后面编写的会盖住前面编写的
如果定位流的元素设置了z-index属性, 那么谁的z-index属性比较大, 谁就会显示在上面
如果两个元素的父元素都没有设置z-index属性, 那么谁的z-index属性比较大谁就显示在上面
如果两个元素的父元素设置了z-index属性, 那么子元素的z-index属性就会失效,