前端 | CSS
定位属性position
的用法
data:image/s3,"s3://crabby-images/ef278/ef278c02823bcc8074fcc0237bed9997b883a665" alt=""
xml
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>CSS_POSITION</title>
<style type="text/css">
.div1 {
width: 360px;
height: 360px;
border: 1px solid black ;
}
.div1_1 {
width: 180px;
height: 180px;
background-color:burlywood ;
}
.div1_2 {
width: 180px;
height: 180px;
background-color:aquamarine;
}
</style>
</head>
<body>
<div class="div1">
<div class="div1_1">div11</div>
<div class="div1_2">div12</div>
</div>
</body>
</html>
data:image/s3,"s3://crabby-images/861f1/861f1b73ed07763bb2828914b471a81265b18629" alt=""
static 静态定位
- 默认的
position
值是static
- 忽略
top
,right
,bottom
,left
,z-index
属性的设置
css
.div1 {
position: static;
width: 360px;
height: 360px;
border: 1px solid black ;
}
.div1_1 {
width: 180px;
height: 180px;
background-color:burlywood ;
}
.div1_2 {
width: 180px;
height: 180px;
background-color:aquamarine;
}
data:image/s3,"s3://crabby-images/be83a/be83a87a982ba025a3793eb4ea8766cf35738700" alt=""
relative 相对定位
- 相对于元素正常位置(
static
)进行的定位
- 可以使用
top
、right
、bottom
、left
属性来调整元素的位置
1 relative
修改div1
div11
与div12
的高度和与div1
一致,宽度为div1
的一半
css
.div1 {
width: 360px;
height: 360px;
border: 1px solid black ;
position: relative;
top:100px;
}
data:image/s3,"s3://crabby-images/e2cc1/e2cc106ecfb85b081d2571ba5477752055c5c3eb" alt=""
div1
包含div11
与div12
,由于div1
整体高度偏移了,看上去整体偏移了
2 relative
修改div11
div1
还原,仅修改div11
css
.div1_1 {
width: 180px;
height: 180px;
background-color: cyan;
position: relative;
left: 180px;
}
data:image/s3,"s3://crabby-images/9188d/9188d00f91d3269478351e3fbb8776c9144693b2" alt=""
- 修改
div12
与div11
的相对定位一致
3 relative
修改div1
和div11
css
.div1 {
width: 360px;
height: 360px;
border: 1px solid black ;
position: relative;
top:100px;
}
.div1_1 {
width: 180px;
height: 180px;
background-color: cyan;
position: relative;
left: 180px;
}
data:image/s3,"s3://crabby-images/09270/092701d40eaad2f4ff8ade7d5d291639fbb782d1" alt=""
absolute 绝对定位
- 不存在父元素,元素将以浏览器窗口为基准进行定位
- 存在父元素,元素将以父元素为基准进行定位
- 可以使用
top
、right
、bottom
、left
属性来调整元素的位置
1 absolute
设置div1
css
.div1 {
width: 360px;
height: 360px;
border: 1px solid black;
position: absolute;
top: 100px;
}
data:image/s3,"s3://crabby-images/48613/486139338f469c0c430f297f5a093e1529f9814b" alt=""
- 与
relative
还是不相同的
2 absolute
设置div12
css
.div1_2 {
width: 180px;
height: 180px;
background-color: orange;
position: absolute;
/* left: 180px; */
}
- 先不设置
left
值时,与relative
是一致的,也就是按照布局展开的
data:image/s3,"s3://crabby-images/b41db/b41db88e296f861ea5cd0faa316294a5e070fe86" alt=""
- 由于没有删除
body
中margin
与padding
的宽度,固有以下影响
data:image/s3,"s3://crabby-images/73a4d/73a4da3b27aeae84c3600ed95723dfc68e06d252" alt=""
- 再次将
div12
的left
设置为180px
将出现空隙
data:image/s3,"s3://crabby-images/64dd8/64dd8c960d0f486d25801387eaeb4f3c0304589c" alt=""
- 受到
body { padding: '8px' }
与.div1 { border: 1px solid black; }
的影响,应该修改为180px + 8px + 1px
用以对齐
data:image/s3,"s3://crabby-images/7d62d/7d62d181682344d74d8ecf6b6d8d4ef07ba18dac" alt=""
- 修改
div11
与div12
的绝对定位一致
3 absolute
设置div11
div11
初步设置absolute
,将使得div12
隐藏到div11
的下方,通过以下两图说明是隐藏的
css
.div1_1 {
width: 180px;
height: 180px;
background-color: cyan;
position: absolute;
}
data:image/s3,"s3://crabby-images/cad72/cad720f1d25fb0b68ecc6471c72148555716b458" alt=""
css
.div1_2 {
width: 200px;
height: 200px;
background-color: orange;
}
data:image/s3,"s3://crabby-images/ccac5/ccac5c3fcdd7a170875a92622fb923d7737ebe88" alt=""
- 重置
div12
,调整div11
css
.div1_1 {
width: 180px;
height: 180px;
background-color: cyan;
position: absolute;
left: 189px;
top: 189px;
}
data:image/s3,"s3://crabby-images/ad618/ad618120201026a8993d0cead27df8207b1f6e17" alt=""
fixed 固定定位
- 以浏览器窗口为基准的定位
- 可以使用
top
、right
、bottom
、left
属性来调整元素的位置
1 fixed
设置div1
css
.div1 {
width: 360px;
height: 360px;
border: 1px solid black;
position: fixed;
top: 100px;
}
data:image/s3,"s3://crabby-images/082bf/082bfdb5dad2f4b510eb37f4d6321806e8c54367" alt=""
div1
已经超出了body
的空间,以浏览器窗口 为基准,距离顶部100px
2 fixed
设置div11
css
.div1_1 {
width: 180px;
height: 180px;
background-color: cyan;
position: fixed;
left: 189px;
top: 189px;
}
data:image/s3,"s3://crabby-images/77157/77157fc3c82c39e9d092079468db77dce760eae0" alt=""
- 与
absolution
不一致,absolution
则是相对父元素 进行的处理,而fixed
是相对浏览器窗口
css
.div1_1 {
width: 180px;
height: 180px;
background-color: cyan;
position: fixed;
left: 189px;
top: 289px;
}
- 将
top: 289px
,发现内容超过div1
高度,原因是fixed
布局不受body
影响,实际高度180px + 100px + 1px
data:image/s3,"s3://crabby-images/3176b/3176bb8393a166919d6d243729e5cdd2514e941c" alt=""
css
.div1_1 {
width: 180px;
height: 180px;
background-color: cyan;
position: fixed;
left: 189px;
top: 281px;
}
data:image/s3,"s3://crabby-images/ae9bf/ae9bff36c367f821df5ec97bd12fb16abed76ff1" alt=""
sticky 粘性定位
- 元素在超过特定值前为相对定位(
relative
),之后为固定定位(fixed
)
- 可以使用
top
、right
、bottom
、left
属性来调整元素的位置
1 sticky
设置div1
css
.div1 {
width: 360px;
height: 360px;
border: 1px solid black;
position: sticky;
top: 100px;
left: 206px;
}
- 无论如何调整
top
大小没有作用,需要设置body
的高度
data:image/s3,"s3://crabby-images/50a38/50a38b98acb926ba63c690c62f748189afc9d8bb" alt=""
-
调整
left
大小,小于206px
是相对定位 ,大于206px
是固定定位。206px
是560px - 362px + 8px
data:image/s3,"s3://crabby-images/8e198/8e198749244630148f0a88017cab37e22db520c8" alt=""
left
等于206px
data:image/s3,"s3://crabby-images/cad25/cad25cc533518e88267d06a41b4ee66ed4f1fd72" alt=""
left
小于206px
data:image/s3,"s3://crabby-images/88ff4/88ff43febdb8f62c78d7dbe6983a507e1e37509a" alt=""
left
大于206px
data:image/s3,"s3://crabby-images/fbb84/fbb849ad8d519eafdd4b55394cf44338f7df3682" alt=""
2 sticky
设置div1.top
css
body {
height: '400px';
}
.div1 {
width: 360px;
height: 360px;
border: 1px solid black;
position: sticky;
top: 100px;
left: 206px;
}
data:image/s3,"s3://crabby-images/6e887/6e887c7a338d8f537760f9ece5e5a4c87fc932dc" alt=""
-
高度配置,需要掌握父元素 的高度,超过父元素 高度才有用,限制父元素高度为
400px
div1
元素高度为362px
,小于46px=400px - 362px + 8px
是相对定位,大于46px
是固定定位
data:image/s3,"s3://crabby-images/62a25/62a25e10c31b93075af7d542b083a5e7d93a41f5" alt=""
top
小于46px
,是相对定位,
data:image/s3,"s3://crabby-images/8492f/8492ff5eb83f007a4b36de0993ee5a1bf8713eb8" alt=""
top
大于46px
data:image/s3,"s3://crabby-images/0802a/0802af02b6fb163c3d3ddce304a10de147cb9bd2" alt=""
- 由于
div1
的父元素是body,也就是浏览器窗体,是不容易判断是相对定位还是固定定位的
3 sticky
设置div11.top
div1
设置为相对定位,top: 100px
css
.div1 {
width: 360px;
height: 360px;
border: 1px solid black;
position: relative;
top: 100px;
}
data:image/s3,"s3://crabby-images/0b0b4/0b0b4469f313f5460cf167cf5f4053b166c5e4e3" alt=""
-
按照上述减法计算临界
362px - 1px - 180px + 8px + 100px
div1
总高度362px
,上下边框总共占2px ,div11
在div1
内部,临界值为360px - 180px
div1
外层还有内容,所以要加上div1 上边框
,div1 相对高度
,body margin
,最终临界值为360px - 180px + 1px + 100px + 8px = 289px
css
.div1_1 {
width: 180px;
height: 180px px;
background-color: cyan;
position: sticky;
top: 289px;
}
data:image/s3,"s3://crabby-images/69632/696328dd71c391b9680675ec2a83c12a3d242883" alt=""
-
top
小于289px
228px
是一个特殊位置,计算公式228px = 408px - 180px
css
.div1_1 {
width: 180px;
height: 180px;
background-color: cyan;
position: sticky;
top: 228px;
}
data:image/s3,"s3://crabby-images/bd843/bd843ccfb35e10ba7fb61967a0699089b199f987" alt=""
top
大于289px
data:image/s3,"s3://crabby-images/f37bb/f37bb4abe0b76216a9cd7774140d097f6a7aa579" alt=""