CSS 属性篇(一):relative与absolute

栏目: CSS · 发布时间: 5年前

内容简介:首先基本了解下position的各个属性值:1、static:默认值。没有定位,元素在正常显示出现(它将忽略top、bottom、left、right、z-index声明)2、relative:生成相对定位的元素,相对于其正常位置进行移动。元素的位置通过 "left", "top", "right" 以及 "bottom" 属性进行规定。

首先基本了解下position的各个属性值:

1、static:默认值。没有定位,元素在正常显示出现(它将忽略top、bottom、left、right、z-index声明)

2、relative:生成相对定位的元素,相对于其正常位置进行移动。元素的位置通过 "left", "top", "right" 以及 "bottom" 属性进行规定。

3、absolute:生成绝对定位的元素,相对于position属性定义为static之外的第一个父元素进行定位。元素的位置通过 "left", "top", "right" 以及 "bottom" 属性进行规定。

4、fixed:生成绝对定位的元素,相对于浏览器窗口进行定位。元素的位置通过 "left", "top", "right" 以及 "bottom" 属性进行规定。

*static属性值和fixed属性都非常的容易理解,我们主要对relative属性值和absolute属性值进行说明。

二、relative

1、定位为relative的元素,虽然可以脱离正常的文档流进行移动,但是其本身在文档流中占据的位置仍然保留。如下图所示:

CSS 属性篇(一):relative与absolute

relative元素进行移动是相对于其本身原来位置进行移动,并且当它移动之后,它仍然占据着原来位置的空间。

三、absolute

定位为absolute的元素,也是脱离正常的文档流,并且其本身在文档流中占据的位置不再保留。如下图所示:

CSS 属性篇(一):relative与absolute

其中黄色背景为absolute的元素,蓝色背景被普通元素,红色背景为二者的父元素(父元素被定义为relative)。

如图所示,absolute元素进行移动是相对于离它最近的定义了position属性并且属性值不为static的父层元素进行移动(这个父层元素可以不是其直接父层)。如果其父层全部都未定义除static之外的position属性,那么它将相对于浏览器显示窗体元素进行移动而非html标签元素。

1、absolute元素的父元素并没有设置position属性,而其祖父元素设置了position属性,absolute元素则相对祖父元素进行移动。

CSS 属性篇(一):relative与absolute
CSS 属性篇(一):relative与absolute

2、absolute元素的父元素并设置position:static属性,而其祖父元素设置了position:relative属性,absolute元素则相对祖父元素进行移动。 CSS 属性篇(一):relative与absolute

3、absolute元素的父元素并设置position:relative属性,祖父元素也设置了position:relative属性,absolute元素则相对父元素进行移动。 CSS 属性篇(一):relative与absolute

4、absolute元素的父元素和祖父元素都没有设置position属性,absolute元素则相对浏览器显示窗体元素(注意:不是html元素)进行移动。 CSS 属性篇(一):relative与absolute

5、如下图所示,在没有设置移动属性(left,right,top,bottom)时,absolute元素处于正常布局中所处的位置,只是属于“浮在空中”的状态,不占据文档流空间。

CSS 属性篇(一):relative与absolute

四、注意

对于上文中,absolute元素如果其父层全部都未定义除static之外的position属性,那么它将相对于浏览器显示窗体元素进行移动而非html标签元素有异议的,我们可以试试一下的代码一试便知。

body,html {
	margin-top:50px;
	height:300px;
}
div {
	width:200px;
	height:200px;
	background:red;
	position:absolute;
	top:20px;
}
复制代码
结果分析:

1、如果div元素距离顶部只有20px,则div是相对浏览器显示窗口移动。

2、如果div元素距离顶部为70px(html的margin-top:50px + top:20px),则div是相对html元素移动。

3、如果div元素距离顶部为120px(html的margin-top:50px + body的margin-top:50px + top:20px),则div是相对body元素移动。

代码传送门:案例代码 by madman0621 (@madman0621) on CodePen

.


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

C语言接口与实现

C语言接口与实现

David R. Hanson / 郭旭 / 人民邮电出版社 / 2011-9 / 75.00元

《C语言接口与实现:创建可重用软件的技术》概念清晰、实例详尽,是一本有关设计、实现和有效使用C语言库函数,掌握创建可重用C语言软件模块技术的参考指南。书中提供了大量实例,重在阐述如何用一种与语言无关的方法将接口设计实现独立出来,从而用一种基于接口的设计途径创建可重用的API。 《C语言接口与实现:创建可重用软件的技术》是所有C语言程序员不可多得的好书,也是所有希望掌握可重用软件模块技术的人员......一起来看看 《C语言接口与实现》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

html转js在线工具
html转js在线工具

html转js在线工具