position 属性用来指定一个元素在网页上的位置,下午主要通过3个维度来讲述:基准点、是否脱标与占有位置、是否需要设置边距,一共有5种定位方式:static、relative、absolute、fixed、sticky。在讲定位之前先讲几个概念:正常模式与脱标:
所谓正常模式,也就是正常占有位置,不影响下一个元素的布局,也就是说没有漂浮起来。常见的有块级元素与内联元素:
// html
<body>
<div>I am div1</div>
<div>I am div2</div>
<div>I am div3</div>
</body>
// css
div {
background-color: lightgrey;
width: 100px;
height: 50px;
}
div:nth-child(2) {
background-color: yellow;
width: 100px;
height: 50px;
}
div:last-child {
background-color: red;
width: 100px;
height: 50px;
}
// html
<body>
<span>I am span1</span>
<span>I am span2</span>
<span>I am span3</span>
</body>
// css
span {
background-color: lightgrey;
width: 100px;
height: 50px;
}
span:nth-child(2) {
background-color: yellow;
width: 100px;
height: 50px;
}
span:last-child {
background-color: red;
width: 100px;
height: 50px;
}
所谓脱标,就是脱离了”标准流“(有的叫”正常流“,英文是”normal flow“),本来该占有的位置就不再占有了,下一个元素会占有它的位置,此时元素会出现重叠现象,通过设置z-index大小来显示元素重叠顺序。
static 是浏览器的默认定位方式,如果没有给元素 style 添加 position,那么就是 static 定位。该定位的特征是: * 基准点:按代码的顺序来决定元素的布局,正常显示模式,即所谓的”标准流“。 * 边偏移:通过设置 top right bottom left 无效。 * 脱标:不脱标,正常占有该有的位置,不影响下一个元素布局。 * 使用场景:清除定位,即一个设置了非static定位的box,不要定位了,就使用static清除,在浏览器调试过程中非常重要,比如,可通过static查看原有的位置应该在哪。
// html
<body>
<div>test static position</div>
</body>
// css
div {
background-color: pink;
top: 100px;
}
relative 相对定位方式,该定位方式的特征是: * 基准点:自己在static定位模式下的位置作为基准点,俗称元素的默认位置。 * 边偏移:必须通过设置 top / right / bottom / left 来准确定位。 * 脱标:不脱标,正常占有该有的位置,不影响下一个元素布局,下一个元素仍然以”标准流“看待它。 * 使用场景:一个很常用的口诀”子绝父相“,如果子元素需要设置absolute定位的时候,父元素可设置relative,当然还有其他场景了,这里不一一列举。
<body>
<div class="father">
<div class="son"></div>
</div>
</body>
// css
.father {
background-color: lightgrey;
width: 300px;
height: 200px;
}
.son {
background-color: yellow;
position: relative;
top: 20px;
width: 200px;
height: 100px;
}
absolute 绝对定位方式,该定位方式的特征是: * 基准点:一般是父元素,但是前提是父元素设置了一个非非非static定位,如果父元素没有设置定位,那么就以浏览器窗口作为基点。 * 边偏移:必须通过设置 top / right / bottom / left 来准确定位。 * 脱标:完全脱标,不占有该有的位置,影响下一个元素布局,下一个元素就当该元素不存在。 * 使用场景:如果一个元素需要以父元素的(0,0)坐标点对齐的时候,可以马上想到 absolute ,还有需要转化为inline-block模式也可以使用absolute。
//html
<body>
<div class="father">
<div class="son"></div>
<div class="son2"></div>
</div>
</body>
// css
.father {
background-color: lightgrey;
width: 300px;
height: 200px;
}
.son {
background-color: yellow;
position: absolute;
top: 20px;
width: 100px;
height: 100px;
}
.son2 {
background-color: red;
top: 20px;
width: 200px;
height: 150px;
}
fixed 固定定位方式,该定位方式的特征是: * 基准点:浏览器窗口为基点,不管页面怎么布局与滚动,该位置就固定不动。 * 边偏移:必须通过设置 top / right / bottom / left 来准确定位。 * 脱标:完全脱标,不占有该有的位置,影响下一个元素布局,下一个元素就当该元素不存在。 * 使用场景:比如页面可恶的广告,你怎么滑动就停在那里不动。
// html
<body>
<div class="father">
<div class="son"></div>
<div class="son2"></div>
</div>
</body>
// css
.father {
background-color: lightgrey;
width: 300px;
height: 200px;
}
.son {
background-color: yellow;
position: fixed;
right: 10px;
width: 100px;
height: 100px;
}
.son2 {
background-color: red;
top: 20px;
width: 200px;
height: 150px;
}
sticky 粘性定位方式,该定位其实包含了 relative 与 fixed 这两种定位模式,但不是同时存在,需要一个触发条件,即边偏移 top / right / bottom / left 的值达到后就会切换 fixed 方式,不同定位方式,就分别显示该方式的定位特征。 * 基准点:relative 方式以自身位置为基准点; fixed 方式以浏览器窗口为基点。 * 边偏移:如果设置 top / right / bottom / left 就会同时具备relative 与 fixed 这两种定位模式,如果没设置就默认 relative, * 脱标:relative 不脱标,fixed 脱标 * 使用场景:比如页面可恶的广告,你怎么滑动就停在那里不动。
// html
<body>
<div class="father">
<div class="son"></div>
<div class="son2"></div>
</div>
</body>
// css
.father {
background-color: lightgrey;
position: relative;
left: 200px;
width: 300px;
height: 1000px;
}
.son {
background-color: yellow;
position: sticky;
top: 30px;
width: 90px;
height: 60px;
}
.son2 {
background-color: red;
top: 20px;
width: 200px;
height: 150px;
}
以上就是对各种定位的解释,在实际工作中也许会很复杂,但基本都是这些定位的巧妙运用,如果讲述有什么错误,欢迎留言评论,码子码图不易,码gif图更不容易,转载请注明出处,谢谢。
示:点击上方"蓝色字体"↑ 可以订阅噢!
摘要 51RGB官方微信position是CSS中非常重要的一个属性,通过position属性,我们可以让元素相对于其正常位置,父元素或者浏览器窗口进行偏移。postion也是初学者容易搞不清楚状况的一个属性,本文将从最基础的知识讲起,谈谈关于positon属性的一些理论与应用。
postion属性我们成为定位,它有4个不同类型的定位,这些类型会影响元素的生成方式,下面我们详细说明position属性。
(1)static
static是position属性的默认值,默认情况下,块级元素和行内元素按照各自的特性进行显示
(2)relative
relative翻译成中文称相对定位,设置了这个属性后,元素会根据top,left,bottom,right进行偏移,关键点是它原本的空间仍然保留。我们看下面例子:
HTML代码
1 2 3 | <div class="relative"> </div> <div></div> |
CSS代码
CSS
1 2 | div { background: #0094ff; width: 250px; height: 100px; } .relative { background: #ff6a00; position: relative; width: 200px; height: 100px; top: 20px; left: 50px; } |
效果图
relative效果
在这个例子中,div.relative相对定位,并且left设置为20px,left设置为50px,其相对于父元素进行偏移,并且原本的空间也占据着,下面的元素并不会顶替上去。
(3)absolute
元素设置成absolute后会脱离文档流,并且不占有原本的空间,后面的元素会顶替上去,而且不论元素是行内元素还是块级元素,都会生成一个块级框,也就是例如行内元素span设置了absolute后就可以设置height和width属性了。看下面例子:
HTML代码
1 2 3 | <span class="absolute"> </span> <div></div> |
1 2 | div { background: #0094ff; width: 250px; height: 100px; } .absolute { background: #ff6a00; position: absolute; width: 200px; height: 100px; top: 20px; left: 50px; } |
效果图
absolute效果
如图所示,span标签被设置成绝对定位,就可以设置height和width属性,而且不占有原本的空间,后面的div元素会顶替上去。
(4)fixedfixed的表现方式类似于absolute,但是相比于absolute相对于不确定的父元素进行偏移,fixed就是相对于浏览器窗口进行偏移
在详解CSS float属性中我们提到包含块这个概念。对于position属性也有包含块这个属性,它要分几种情况来讨论:
1.根元素的包含块,根元素一般是html元素,有些浏览器会使用body作为根元素,大多数浏览器,初始包含块是一个视窗大小的矩形
2.非根元素的包含块,如果该元素的position是relative或static,它的包含块是最近的块级框,表的单元格或行内块的内容边界
我们举例进行说明,
HTML代码
1 2 3 4 5 6 | <div> 我是父级元素的内容 <div class="relative"> 相对定位元素 </div> </div> |
包含块
这是相对定位元素的包含块,为最近的块级框,表的单元格或行内块的内容边界,相对定位元素相对于其包含块进行偏移,我们可以简单理解为相对于其原来的位置进行偏移。
3.非根元素的包含块,如果该元素的position是absolute,则包含块为最近的position不是static的祖先元素。简单来说,它的包含块会从父级元素一直向上查找,找到第一个position不是static的元素为止。
前面的例子中已经涉及到偏移属性,它指的是元素相对于其包含块的偏移,我们称其为偏移属性,分别是top,bottom,left,right,依次代表上下左右。他们的值可以是具体的数值,也可以是百分比。如果是百分比,top和bottom是相对于包含块高度的百分比,left和right是相对于宽度的百分比。它们也可以设置负值,即有可能将元素移动到包含块的外边。
接下来我们了解一下绝对定位的详细细节。
一个元素被设置为绝对定位时,会脱离文档流,然后相对其包含块进行偏移。
一般来说,我们会将一个元素设置为relative来作为absolute元素的包含块,我们看看下面的例子:
HTML代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | <div class="absolute"> 相对于初始包含块定位 </div> <br /> <br /> <br /> <br /> <br /> <br /> <div class="relative"> <div class="absolute"> 相对于最近relative祖先元素定位 </div> </div> |
1 2 3 | div { background: #0094ff; width: 250px; height: 100px; } .relative { background: #ff6a00; position: relative; width: 200px; height: 100px; top: 20px; left: 50px; } .absolute { background: #988c8c; position: absolute; width: 200px; height: 100px; top: 20px; left: 50px; } |
效果图
基本的绝对定位
如图所示,有两个绝对定位元素,第一个元素没有position不是static的祖先元素,所以它的包含块是body,根据body进行偏移,第二个绝对定位元素设置了一个relative的父元素,它根据父元素进行偏移。
元素设置成绝对定位后会脱离文档流,并且失去占用的空间,而且如果偏移的位置接近,会造成重叠问题。看看下面的例子:HTML代码
1 2 3 4 5 6 7 8 | <div class="relative"> <div class="absolute"> 相对于最近relative祖先元素定位1 </div> <div class="absolute light"> 相对于最近relative祖先元素定位2 </div> </div> |
1 2 3 4 | div { background: #0094ff; width: 250px; height: 100px; } .relative { background: #ff6a00; position: relative; width: 500px; height: 300px; top: 20px; left: 50px; } .absolute { background: #988c8c; position: absolute; width: 200px; height: 100px; top: 20px; left: 50px; } .light { background: #f3d6d6; top: 70px; left: 80px; } |
效果图
绝对定位的重叠问题
我们可以看到,第二个绝对定位元素盖住了第一个元素,那怎么让第一个元素盖住第二个元素呢,这就要用到z-index属性,这个属性表示元素的叠加顺序,默认情况下,z-index为0,数值越高的元素层级越高,就可以盖住低于其层级的元素,我们设置第一个原色的z-index为10,结果如下
绝对定位的重叠问题
如果两个元素的层级相同,则越后面的元素会覆盖前面的元素,默认情况下,第二个元素就会盖住第一个元素。
fixed定位很简单,类似与absoulte,但是它的包含块就是浏览器窗口,相对来说简单很多。常见的应用比如固定导航,回到顶部。在这里不再赘述,大家可以查找相关资料。
relative定位的元素进行偏移后,不会脱离文档流,还有占据原本的空间。除此之外,我们还要注意一个细节:如果元素设置了margin为负值之后发生重叠的情况下,相对定位的元素会覆盖普通元素。我们看看下面的例子:HTML代码
1 2 3 4 5 6 | <div class="no-relative"> 未相对定位的元素 </div> <div class="minus-margin"> 负margin元素 </div> |
1 2 3 4 | div { background: #0094ff; width: 250px; height: 100px; } .no-relative { background: #ff6a00; width: 200px; height: 100px; } .relative { background: #ff6a00; width: 200px; height: 100px; position: relative; } .minus-margin { margin-top: -30px; } |
效果图
未相对定位时没有覆盖
默认情况下,两个元素都是正常的元素,设置了负的margin属性后,后面的元素会覆盖前面的元素,我们修改第一个元素的class为relative,可以看到效果如下:
相对定位时覆盖
添加了相对定位后,第一个元素就会覆盖其他正常的元素了。
relative属性最经常的一个应用应该是作为absolute元素的包含块了,为了限制absolute元素的偏移位置,常常设置其父元素为relative来作为其包含块。
position的应用非常频繁,下面我来说说常见的一些场景:
在电商网站中,我们常常可以看到产品的左上角或右上角有一些比如“新品”,“促销”,“热卖”等标签,比如下图:
产品标签
这个是怎么实现的呢,我们来模拟一下:HTML代码:
1 2 3 4 5 6 | <div class="product"> 我是产品 <span class="hot"> 热卖 </span> </div> |
CSS代码:
CSS
1 2 | .product { width: 150px; height: 150px; background: #0094ff; position: relative; } .hot { position: absolute; right: 10px; top: 10px; width: 40px; height: 20px; background: #ff6a00; text-align: center; } |
效果如下:
产品标签
如图所示,右上角有一个标签。原理很简单,就是设置父元素相对定位,标签元素绝对定位,然后相对于父元素偏移到右上角。
自动完成框是一个非常常见的应用,其生成的下拉菜单也是用到了position属性。我们先看看下面的效果:
、
自动完成输入框
这是一个很简单常见的下来自动完成框,我们来看看它的HTML和CSS代码:HTML代码
1 2 3 4 5 6 7 | <input class="search-box" type="text" placeholder="请输入关键字" value="position" /> <ul style="left:58px;"> <li>position属性</li> <li>position应用</li> <li>position是什么</li> <li>position翻译</li> </ul> |
1 2 3 4 | .search-box { border: 1px solid #ccc; width: 200px; padding: 5px; height: 24px; margin-left: 50px; } ul, li { list-style-type: none; } ul { border: 1px solid #ccc; width: 210px; position: absolute; } li { padding: 5px; } |
这个原理也很简单,通过设置下拉菜单为绝对定位,然后设置其left属性与输入框对齐。
当然position的应用还有很多,比如布局,比如fixed可以用来做固定导航菜单,网页右下角的固定菜单等,有兴趣的同学可以自行查找相关资料进行学习。
position属性是一个容易让初学者迷惑的属性,尤其是absolute和relative的应用。要用好它们,首先要从absolute和relative的基本特性开始了解,理解了他们的特性之后应用起来就得心应手了,了解基本原理后,多多写几个例子从实践中去体会它们的特性,慢慢的就会熟悉了。
想认识志同道合的朋友一起学习web
加入我们的学习QQ群 19066743
丰富的学习资源,周一到周四免费直播公开课
长按图片,识别二维码即可入群
你可能感兴趣的精彩内容
微信:UI设计自学平台加关注
长按关注:《UI设计自学平台》
局的核心是position属性,对元素盒子应用这个属性,可以相对于它在常规文档流中的位置重新定位。position属性有4个值:static、relative、absolute、fixed,默认值为static。
static :默认文档流,正常显示;relative:相对定位;absolute:绝对定位;fixed:固定定位。
HTML代码:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>定位</title>
<script type="text/javascript" src="demo.js"></script>
<link rel="stylesheet" type="text/css" href="demo.css">
</head>
<body>
<p>1</p>
<p id="p2">2</p>
<p>3</p>
<p>4</p>
</body>
</html>
css:
*{
margin: 0 ;
padding: 0;
}
p{
position: static;
background: #ccc;
margin-bottom: 15px;
}
#p2{
position:relative;
top: 20px;
left: 20px;
}
1 将第二个p元素position属性设为(绝对定位) relative, 设置top和left值:
图示:
发现:第二个段落相对于原来的位置向下和右移动了20px。
结论:绝对定位的元素会相对于原来在文档流中的默认位置进行改变;并且这个元素不会影响其他元素,只是相对于自己原来的位置改变了。
PS:可以给top和left属性设定负值,把元素向上、向左移动。
2 将第二个p元素position的属性改为(相对定位)absolute,设置top和left值:
图示:
发现:第二个段落相对于浏览器窗口向下和右,移动了20px。且原来的位置被占据了。
结论:相对定位默认以body为参照物进行定位;并且相对定位已经脱离文档流, margin-bottom: 15px ;失效。
PS:如果给父元素的position属性设置了relative,则以父元素为参照物。如果父元素没有,则看父元素的父元素有没有,如果都没则以body为参照物。
3 将第二个段落position的属性改为(固定定位)fixed,设置top和left值:
发现与绝对定位相似,实际上fixed表示固定在body的某个位置不随页面的滚动而改变。
*请认真填写需求信息,我们会在24小时内与您取得联系。