以前一直不懂这个position,今天工作碰到了,就稍稍总结一下,以便以后翻看
CSS position 属性值:
absolute | 生成绝对定位的元素,相对于 static 定位以外的第一个父元素进行定位。 元素的位置通过 "left", "top", "right" 以及 "bottom" 属性进行规定。 |
fixed | 生成绝对定位的元素,相对于浏览器窗口进行定位。 元素的位置通过 "left", "top", "right" 以及 "bottom" 属性进行规定。 |
relative | 生成相对定位的元素,相对于其正常位置进行定位。 因此,"left:20" 会向元素的 LEFT 位置添加 20 像素。 |
static | 默认值。没有定位,元素出现在正常的流中(忽略 top, bottom, left, right 或者 z-index 声明)。 |
inherit | 规定应该从父元素继承 position 属性的值。 |
其实无论是absolute还是relative都可以叫做相对定位,只是定位时参照的元素不一样,
absloute参照的是它的长辈中第一个有position属性的元素进行定位,先找爸爸,找不到再找爷爷,一直往上,如果都没有,那就以body为参照元素。
relative参照的是它原来应该在的位置,即没加position属性时它应该在的位置。
fixed参照的就是body元素
以前一直弄不懂top,left,right,bottom,现在终于弄懂了,就是你和你的参照元素在不同方向上的距离。比如说top:50px,那就是和参照元素的上边相距50px,其他的上下左右依此类推。