定位
五种定位
- static: 默认值。没有定位,不脱离文档流(忽略 top, bottom, left, right 或者 z-index 声明)。
- absolute: 相对于 static 定位以外的第一个祖先元素进行定位。脱离文档流。
- fixed: 相对于浏览器视窗进行定位。脱离文档流。
- relative: 生成相对定位的元素,相对于其正常位置进行定位,不脱离文档流。
- sticky: relative + fixed,但不脱离文档流,需要指明 top,表示滚动到相对于 static 定位以外的第一个祖先元素的位置,变成类似 fixed 效果。demo
tip
position 还可以是: inherit
, initial
, unset
, 这是一般 CSS 属性都具有的。
注意 sticky 的兼容性:
data:image/s3,"s3://crabby-images/92c6b/92c6bbaa2ca7c8a3aa92228ab51463a6652d70bc" alt=""
相对定位
Demo DOM 结构:
data:image/s3,"s3://crabby-images/188d8/188d8aa560a442ab396f942e5898aa98268d7614" alt=""
tip
relative
和 sticky
都未脱离文档流, demo
data:image/s3,"s3://crabby-images/dfaa5/dfaa55bd3807e37bfb1184d8e1cd547677e5716d" alt=""
可以观察到黄色部分在紧紧挨着,没有发生重叠,所以相对定位其实并没有脱离文档流。
data:image/s3,"s3://crabby-images/7b92b/7b92b48fbcfb4778523a88d2e323c9c03316b405" alt=""
绝对定位
tip
广义的绝对定位包括 absolute
和 fixed
,它们都会脱离常规流和文本流,demo
data:image/s3,"s3://crabby-images/488ca/488caf0e873e9167326bcb547b79202910b02c5e" alt=""
和 float 一样的是,旁边的盒子无视了蓝色 div 的存在,也是顶着左边边框定位。但是文本也无视了蓝色 div 的存在,顶着左边边框定位。
data:image/s3,"s3://crabby-images/62a82/62a8219b769f1a0372033074f55164dbce9900ff" alt=""
caution
绝对定位可以让元素块状化。
caution
绝对定位的盒子, float
会被重置为 none