视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
cssposition属性中:absolute与relative的区别
2020-11-27 18:50:57 责编:小采
文档

如果用 position来布局页面,父级元素的position 属性必须为relative,而定位于父级内部某个位置的元素,最好用absolute,因为它不受父级元素的padding 的属性影响,当然你也可以用 position,不过到时候计算的时候不要忘记 padding 的值。”

任何元素的默认position 的属性值均是static,静态。今天51RGB Q群186242343主要讲relative(相对)以及absolute(绝对)。

【position:absolute】
意思是:他的意思是绝对定位,他默认参照浏览器的左上角,配合TOP、RIGHT、BOTTOM、LEFT(下面简称TRBL)进行定位,有以下属性:
1)如果没有TRBL,以父级的左上角,在没有父级的时候,他是参照浏览器左上角,如果在没有父级元素的情况下,存在文本,则以它前面的最后一个文字的右上角为原点进行定位但是不断开文字,覆盖于上方。
2)如果设定TRBL,并且父级没有设定position 属性,那么当前的absolute 则以浏览器左上角为原始点进行定位,位置将由TRBL 决定。
3)如果设定TRBL,并且父级设定position 属性(无论是absolute 还是relative),则以父级的左上角为原点进行定位,位置由TRBL 决定。即使父级有Padding 属性,对其也不起作用,说简单点就是:它只坚持一点,就以父级左上角为原点进行定位,父级的padding对其根本没有影响。

以上三点可以总结出,若想把一个定位属性为absolute 的元素定位于其父级元素内,只有满足两个条件,
第一:设定TRBL
第二:父级设定Position 属性
上面的这个总结非常重要,可以保证你在用absolue 布局页面的时候,不会错位,并且随着浏览器的大小或者显示器分辨率的大小,而不发生改变。
只要有一点不满足,元素就会以浏览器左上角为原点,这就是初学者容易犯错的一点,已经定位好的板块,当浏览器的大小改变,父级元素会随之改变,但是设定Position 属性为

absolute 的板块和父级元素的位置发生改变,错位了,这就是因为此时元素以浏览器的右上角为原点的原因。
初学者很容易犯错的是,不清楚Position 属性为absolute 的板块,若想定位到父级板块中,并且当浏览器的大小改变或显示器的分辨率改变,布局不发生改变,是需要满足两个条件的,只要有一点不满足,元素就会以浏览器左上角为原点,从而导致页面布局错位。

【position:relative】
意思是相对定位,他是默认参照父级的原始点为原始点,无父级则以文本流的顺序在上一个元素的底部为原始点,配合TRBL 进行定位,当父级内有padding 等CSS 属性时,当前级的原始点则参照父级内容区的原始点进行定位,有以下属性:
1)如果没有TRBL,以父级的左上角,在没有父级的时候,他是参照浏览器左上角(到这里和absolute 第一条一样),如果在没有父级元素的情况下,存在文本,则以文本的底部为原始点进行定位并将文字断开(和absolut 不同)。
2)如果设定TRBL,并且父级没有设定position 属性,仍旧以父级的左上角为原点进行定位(和absolut 不同)
3)如果设定TRBL,并且父级设定position 属性(无论是absolute 还是relative),则以父级的左上角为原点进行定位,位置由TRBL 决定(前半段和absolut 一样)。如果父级有Padding 属性,那么就以内容区域的左上角为原点,进行定位(后半段和absolut 不同)。

以上三点可以总结出,无论父级存在不存在,无论有没有TRBL,均是以父级的左上角进行定位,但是父级的Padding 属性会对其影响。
综合上面对relative 的叙述,我们就可以将position 属性为relative 的p 视成可以用TRBL 进行定位的的普通p,或者说只要将我们平时布局页面的p 的CSS 属性中加上position:relative 后,就不只是用float 布局页面了,还可以用TRBL 进行布局页面了,或者说加上position:relative 的p 也可以像普通的p 进行布局页面了,只不过还可以用TRBL进行布局页面。但是position 属性为absolute 不可以用来布局页面,因为如果用来布局的话,所有的p 都相对于浏览器的左上角定位了,所以只能用于将某个元素定位于属性为absolute 的元素的内部某个位置,这样我们就可以总结比较重要的结论既然属性为absolute 的元素用来定位某元素在父级中位置,就少不了TRBL,这时候根据一开始讲的absolute 的第三条,如果父级元素没有
position 属性那么absolute 元素就会脱离父级元素,但是如果是布局页面,父级元素position 的属性又不能为absolute,不然就会以浏览器左上角为原点了,所以父级元素的position 属性只能为relative!

属性为relative 的元素可以用来布局页面,属性为absolute 的元素用来定位某元素在父级中的位置

总结:如果用position来布局页面,父级元素的position属性必须为relative,而定位于父级内部某个位置的元素,最好用absolute,因为它不受父级元素的padding的属性影响,当然你也可以用position,不过到时候计算的时候不要忘记padding的值。
但是定位(position)有一个缺点,不会自适应内部元素的高度,所以平时我们在布局页面的时候,如果某个或者某些模块高度永远不变,就可以用定位,但是帆建议大家布局页面的时候,还是要以Float 为主,Position 为辅!这样你才能做出高质量的页面。

最后,请大家记住我这句话:“布局页面,Float为主 ,Position为辅!”

下载本文
显示全文
专题