html学习之路(一)深入理解css中position属性

链接

position属性之:static定位

static定位是HTML元素的默认值,即没有定位,元素出现在正常的流中,因此,这种定位就不会收到top,bottom,left,right的影响。

html代码

css代码

.wrap{width: 300px;height: 300px; background: red;}
.content{position: static; top:100px; width: 100px;height: 100px; background: blue;}

效果图如下


html学习之路(一)深入理解css中position属性_第1张图片
static定位

结论:虽然设置了static以及top,但是元素仍然出现在正常的流中


position属性之:fixed定位

fixed定位是指元素的位置相对于浏览器窗口是固定位置,即使窗口是滚动的它也不会滚动,且fixed定位使元素的位置与文档流无关,因此不占据空间,且它会和其他元素发生重叠。

html代码如下:

我是使用fix来定位的!!!所以我相对于浏览器窗口,一直不动。

css代码如下:

body{height:1500px; background: green; font-size: 30px; color:white;}
.content{ position: fixed; right:0;bottom: 0; width: 300px;height: 300px; background: blue;}
html学习之路(一)深入理解css中position属性_第2张图片
fixed定位

结论:右下角的div永远不会动,就像经常弹出来的广告


position属性之:relative定位

相对定位元素的定位是相对它自己的正常位置的定位。

结论:即使相对元素的内容移动了,但是预留空间的元素仍然保存在正常流动,也就是说相对移动之后,不会对下面的其他元素造成影响


position属性之:absolute定位

绝对定位的元素相对于最近的已定位父元素,如果元素没有已定位的父元素,那么它的位置相对于。

例①



    
    绝对定位
    


    
什么?
html学习之路(一)深入理解css中position属性_第3张图片
效果

结论:只在span中设置了position:absolute;而在其父元素中都没有,于是它的位置是相对于html的。

例②



    
    绝对定位
    


    
什么?
# 相较于上一个例子,我只修改了class为son的元素的css,设置为position:relative;
html学习之路(一)深入理解css中position属性_第4张图片
效果图

我们发现现在span的位置是相对于设有position属性的class为son的父元素的。

例③



    
    绝对定位
    


    
什么?
#这个例子我只是修改了第一个例子中的css--设置了position:absolute;效果如下:
html学习之路(一)深入理解css中position属性_第5张图片
效果图

我们发现,现在span的定位是相对于具有position:absolute的属性的class为parent的父元素。

例④



    
    绝对定位
    


    
什么?

相对于例1,我添加了fixed的position属性,发现结果和例3是一模一样的。

例⑤



    
    绝对定位
    


    
什么?

相对于例1,我添加了static的position属性(即html的默认属性),结果和例1是一样的。

综上所述,当某个absolute定位元素的父元素具有position:relative/absolute/fixed时,定位元素都会依据父元素而定位,而父元素没有设置position属性或者设置了默认属性,那么定位属性会依据html元素来定位。

你可能感兴趣的:(html学习之路(一)深入理解css中position属性)