1,绝对定位问题
1,绝对定位元素的特性
display
默认为block
。所以行内元素设置绝对定位后可直接设置宽高。- 脱离文档流,所以
margin: auto
失效。 - 绝对定位元素相对于最近的非 static 祖先元素定位。当这样的祖先元素不存在时,则相对于 ICB(initial containing block,初始包含块)。
2,初始包含块问题
设置 bottom
时,参考点是浏览器首屏的底部,而不是页面的底部。
2,粘性定位
一句话总结:可以认为是相对定位和固定定位的混合,定位元素在滚动到某个阈值之前表现为相对定位,之后表现为固定定位。
先看下实际应用:
实现起来也比较简单,只需要给粘性定位元素一个 top 值即可。当定位元素距离浏览器视口顶部到达 top 值后,就表现为固定定位。
举例:
<head>
<style>
* {
margin: 0;
padding: 0;
}
.header {
height: 200px;
background-color: seagreen;
}
.sticky {
position: sticky;
top: 20px;
width: 50px;
height: 50px;
background-color: salmon;
}
.content {
height: 800px;
background-image: linear-gradient(#e66465, #9198e5);
}
</style>
</head>
<body>
<div class="header">顶部其他元素</div>
<div class="sticky"></div>
<div class="content"></div>
</body>
注意点:
- 至少得指定
top
,right
,bottom
,left
其中之一,才可使粘性定位生效。否则其行为与相对定位相同。 - 和其他定位一样,
top
优先级大于bottom
,left
优先级大于right
- 粘性定位元素的包含块,设置
overflow: hidden;
会使粘性定位失效。
<head>
<style>
.box {
position: relative;
overflow: hidden;
}
</style>
</head>
<body>
<div class="box">
<div class="header">顶部其他元素</div>
<div class="sticky">one</div>
<div class="content"></div>
</div>
</body>
以上。
原文地址:https://blog.csdn.net/qq_40147756/article/details/134747939
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_36008.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。