position粘性定位sticky
position:sticky粘性定位
sticky是css定位中不太常用的一種定位,但是可以根據粘性定位的特性 在頁面中達到你想要的效果。
像是某些網站,在主導航欄下面還會有副導航欄,要實現頁面往下拉,副導航欄一直定位在頁面頂部,除了可以用js監聽onscroll事件來實現,還可以通過sticky定位輕松搞定。
1.定義
粘性定位可以被認為是相對定位和固定定位的混合。元素在跨越特定閾值前為相對定位,之后為固定定位。
2.使用條件:
1. 父元素不能設置 overflow:hidden; 或者 overflow:auto; 屬性;
2. 必須制定 top、bottom 、left 、 right 4個值之一,否則只會處於相對定位;
3. 父元素的高度不能低於sticky 元素的高度;
4. sticky 元素僅在其父元素內生效;
簡單寫個demo
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
<style>
.sticky{
width: 100%;
color:white;
background-color: cadetblue;
border: 1px solid red;
position: sticky;
top:0;
}
.div{
height: 3000px;
text-align: center
}
</style>
</head>
<body>
<div class="div">
<p>第一行</p>
<p>第二行</p>
<p class="sticky">第三行</p>
<p>第四行</p>
<p>第五行</p>
<p>第六行</p>
<p>第七行</p>
<p>第八行</p>
<p>第九行</p>
<p>第十行</p>
<p>第十一行</p>
<p>第十二行</p>
<p>第十三行</p>
<p>第十四行</p>
<p>第十五行</p>
<p>第十六行</p>
<p>第十七行</p>
<p>第十八行</p>
</div>
</body>
</html>
頁面展示如下:

下拉滾動條

這里給第三行加了position:sticky屬性,設置了top:0,當往下拖動的時候,第三行就會固定在頂部位置

