HTML + CSS 连载 | 50 - 绝对定位元素的特点(上)一、将 position 设置为 absolute/f
一、将 position 设置为 absolute/fixed 元素的特点
官方文档中将 position
属性的属性值设置为 absolute/fixed
的元素成为绝对定位元素Absolute Positioned Element
,注意要和绝对定位进行区分;将元素设置为绝对定位
或者固定定位
后,元素会有如下特点:
- 可以随意设置宽高,不设置宽和高的情况下宽高默认由内容决定
- 不再受标准流的约束,不再严格执行从上到下、从左到右的排布,不再严格区分块级、行内级,并且块级、行内级的很多特性都会消失
- 不再给父元素汇报宽高数据
- 脱标元素内部默认还是按照标准流布局
可以随意设置宽高
创建 HTML 页面,我们给 strong
元素设置为绝对定位,给 div.box
元素设置绝对定位,具体代码如下:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
.container {
width: 800px;
height: 700px;
background-color: #f00;
position: relative;
}
.box {
width: 500px;
height: 500px;
background-color: #0f0;
/*绝对定位,位置相对于 .container*/
position: absolute;
right: 0;
bottom: 0;
}
strong {
/*绝对定位,位置相对于 .box*/
position: absolute;
left: 0;
bottom: 0;
background-color: #00f;
}
img {
width: 100px;
height: 100px;
}
</style>
</head>
<body>
<div class="container">
<div class="box">
<span>我是span</span>
<strong>我是strong</strong>
<img src="../images/juejin.png" alt="" >
<div>我是div</div>
</div>
</div>
</body>
</html>
打开 HTML 页面,效果如下:
接着我们给 strong
元素设置宽高,代码如下所示:
strong {
position: absolute;
left: 0;
bottom: 0;
background-color: #00f;
width: 100px;
height: 40px;
}
刷新页面,效果如下:
可以看到在做了绝对定位后,strong
元素设置的宽和高生效了,原本 strong
作为一个行内元素是不能够设置宽高的。这是因为设置了绝对定位以后,strong
元素的类型表现符合 inline-block
元素的特性,因此可以随意设置宽高并且宽高默认由内容决定。
在没有设置宽高的时候,默认是包裹内容的,也就是说宽高由内容决定的。
需要注意的是设置了绝对定位以后,并不是把元素变成 inline-block
类型,并且也不需要在做 display: inline-block
这类设置了。
不再给父元素汇报宽高数据
设置为 absoulte/fixed
之后就脱离了标准流,不再严格按照从上到下、从左到右的顺序排列,不再有行内级元素块级元素等特点,一个比较显著的现象就是不再给父元素汇报宽高。
创建 HTML 页面,具体代码如下:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
.box {
background-color: #f00;
}
</style>
</head>
<body>
<div class="box">
<strong>我是strong</strong>
</div>
</body>
</html>
刷新页面,效果如下:
当前 div.box
有一定的宽度和高度,设置 strong
为绝对定位,代码如下:
.box strong {
position: absolute;
}
刷新页面,效果如下:
strong
设置绝对定位之前 div.box
的宽度和高度是由 strong
内容撑起来的,也就是说 strong
会向 div.box
汇报宽高数据,设置绝对定位之后,strong
脱离标准流就跟 div.box
没有关系了,并且位置是相对于视口,strong
元素也就不再属于 div.box
的子元素了,红色的盒子 div.box
也就没有了,也就是 div.box
压根就没有高度了。
脱标元素内部默认还是按照标准流布局
创建 HTML 页面,具体代码结构如下:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
.box {
background-color: #f00;
}
.box strong {
position: absolute;
width: 200px;
height: 200px;
background-color: #0f0;
}
</style>
</head>
<body>
<div class="box">
<strong>
<!--strong的子元素依然按照标准排列-->
<span>我是span</span>
<i>我是i</i>
</strong>
</div>
</body>
</html>
刷新页面,效果如下:
strong
作为定位元素,但是他的子元素依然是按照原来的标准流,并没有发生任何变化。
转载自:https://juejin.cn/post/7295964269966983183