理解 position:relative 与 position:absolute
2016-06-10 14:14
459 查看
理解 position:relative 与 position:absolute
有三个值,static
(静态)、
relative
(相对)、
absolute
(绝对);由于
static
是所有页面元素的默认值,因此设置元素的定位类型时几乎不用这个值,除非用于覆盖之前的定义。
对于后两者,一般应用:在一个相对定位的元素里面放置一个绝对定位的元素,如图:
子元素
B
可以通过
top
、
right
、
bottom
、
left
来精确定位,定位的参考目标就是其具有相对定位属性的父级元素
A
;并且设置这些偏移后,产生的空隙会被后面的元素填充(如果后面的元素足够尺寸的话)。由于
B
元素具有
absolute
定位属性,相当于从文档流中抽取出来,浮动在原平面排版上,形成“层”,如果有多个“层”,层与层之间就必然会有谁覆盖谁,谁在上谁在下的竞争关系,因此,为解决这个竞争,就产生了
z-index
(空间坐标系的
Z
轴)
属性,谁的值大,谁就在上面。另外,如果父级元素
A
没有设置
relative
,那么
B
元素就会以
body
标签当作参考点。
对于具有
position:relative
属性的元素
A
,其
top
、
right
、
bottom
、
left
四个方向的位置偏移就会以该元素的原来位置作为参考点,而不是像上面说的,以具有
relative
定位属性的父级元素或
body
作为参考点。在设置了偏移后产生了空隙,其周围的元素并不会填充这些空隙,即使它们足够尺寸
(演示
)
。值得注意的是,此时元素
A
的
margin
,
margin
将作用于该元素的原来位置,由于原位置产生偏移,该元素的最终位置将是
margin
与
top
、
right
、
bottom
、
left
共同作用后的位置,并且其周围元素的位置也将产生影响。
回过头来再看看
relative
里面的
absolute
,比如上面的
A
、
B
两个元素,如果两个元素都设置了
top
、
right
、
bottom
、
left
,对于元素
B
来说,其位置偏移的参考点是元素
A
偏移后的位置,不是元素
A
的原位置,同样,如果元素
B
有
margin
,其参考点也是元素
A
偏移后的位置,这点很重要,这才是
absolute
的概念
相关文章推荐
- Web布局连载——两栏固定布局(五)
- [div+css]晒晒最新制作专题推广页模板
- 盒子模型
- CSS选择器
- CSS样式优先权
- [css] line-height 百分比单位和数值单位的区别
- Apple官网研究之使用Justify布局导航
- 关于前端的思考与感悟
- rem : web app适配的秘密武器
- jquery高级应用之Deferred对象
- 设计更快的网页(三):字体和 CSS 调整
- 纯CSS制作的新闻网站中的文章列表
- 10条影响CSS渲染速度的写法与使用建议第1/3页
- BS项目中的CSS架构_仅加载自己需要的CSS
- 很不错的 CSS Hack 又学了一招
- 发一个css比较清爽的写法
- CSS expression控制图片自动缩放效果代码[兼容 IE,Firefox]
- css布局网页水平居中常用方法
- CSS经典技巧十则第1/2页