国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > CSS > 正文

CSS使用position:sticky 實現粘性布局的方法

2024-07-11 08:31:54
字體:
來源:轉載
供稿:網友

簡介

前面寫了一篇文章講解了position常用的幾個屬性:《CSS基礎篇-- position屬性講解》

一般都知道下面幾個常用的:

{position: static;position: relative;position: absolute;position: fixed;}

在https://developer.mozilla.org/zh-CN/docs/Web/CSS/position還說了下面這三個值:

/* 全局值 */position: inherit;position: initial;position: unset;

估計大部分都沒有用過position:sticky吧。這個屬性值還在試驗階段。怎樣描述它呢?

初窺 position:sticky

sticky 英文字面意思是粘,粘貼,所以姑且稱之為粘性定位。下面就來了解下這個處于實驗性的取值的具體功能及實用場景。

這是一個結合了 position:relative 和 position:fixed 兩種定位功能于一體的特殊定位,適用于一些特殊場景。

什么是結合兩種定位功能于一體呢?

元素先按照普通文檔流定位,然后相對于該元素在流中的 flow root(BFC)和 containing block(最近的塊級祖先元素)定位。

而后,元素定位表現為在跨越特定閾值前為相對定位,之后為固定定位。

這個特定閾值指的是 top, right, bottom 或 left 之一,換言之,指定 top, right, bottom 或 left 四個閾值其中之一,才可使粘性定位生效。否則其行為與相對定位相同。

sticky:對象在常態時遵循常規流。它就像是relativefixed的合體,當在屏幕中時按常規流排版,當卷動到屏幕外時則表現如fixed。該屬性的表現是現實中你見到的吸附效果。

常用場景:當元素距離頁面視口(Viewport,也就是fixed定位的參照)頂部距離大于 0px 時,元素以 relative 定位表現,而當元素距離頁面視口小于 0px 時,元素表現為 fixed 定位,也就會固定在頂部。

代碼:

{ position: -webkit-sticky; position: sticky; top: 0;}

如下圖表現方式:

距離頁面頂部大于20px,表現為 position:relative;

距離頁面頂部小于20px,表現為 position:fixed;

運用 position:sticky 實現頭部導航欄固定

html代碼:

<div class="con"> <div class="samecon"> <h2>標題一</h2> <p>這是一段文本</p> <p>這是一段文本</p> <p>這是一段文本</p> </div> <div class="samecon"> <h2>標題二</h2> <p>這是一段文本</p> <p>這是一段文本</p> <p>這是一段文本</p> </div> <div class="samecon"> <h2>標題三</h2> <p>這是一段文本</p> <p>這是一段文本</p> <p>這是一段文本</p> </div> <div class="samecon"> <h2>標題四</h2> <p>這是一段文本</p> <p>這是一段文本</p> <p>這是一段文本</p> </div> <div class="samecon"> <h2>標題五</h2> <p>這是一段文本</p> <p>這是一段文本</p> <p>這是一段文本</p> </div> <div class="samecon"> <h2>標題五六</h2> <p>這是一段文本</p> <p>這是一段文本</p> <p>這是一段文本</p> </div></div>
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 固阳县| 墨玉县| 黄平县| 双桥区| 阿克苏市| 大余县| 沿河| 金门县| 祥云县| 朔州市| 南城县| 邵阳县| 洛隆县| 牙克石市| 苍南县| 齐齐哈尔市| 衡水市| 滕州市| 洪泽县| 平乡县| 阿坝县| 阳新县| 灌云县| 丹寨县| 西丰县| 三台县| 榆树市| 罗定市| 武强县| 富阳市| 绥棱县| 郧西县| 永福县| 峨眉山市| 云霄县| 邳州市| 鄄城县| 柳州市| 五寨县| 崇义县| 龙泉市|