日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

position:sticky介绍

發布時間:2024/5/14 编程问答 42 豆豆
生活随笔 收集整理的這篇文章主要介紹了 position:sticky介绍 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

用戶的屏幕越來越大,而頁面太寬的話會不宜閱讀,所以絕大部分網站的主體寬度和之前相比沒有太大的變化,于是瀏覽器中就有越來越多的空白區域,所以你可能注意到很多網站開始在滾動的時候讓一部分內容保持可見,比如,側邊欄的部分區域。position:sticky為此而生。

position:sticky用法

position:sticky是一個新的css3屬性,它的表現類似position:relative和position:fixed的合體,在目標區域在屏幕中可見時,它的行為就像position:relative; 而當頁面滾動超出目標區域時,它的表現就像position:fixed,它會固定在目標位置。

使用起來也非常簡單:

.sticky { position: -webkit-sticky; position:sticky; top: 15px; }

目前來說還需要用私有前綴~~

sticky生效條件:

1、父元素不能overflow:hidden或者overflow:auto屬性。(mescroll-body設置:sticky="true"即可, mescroll-uni本身沒有設置overflow)
2、必須指定top、bottom、left、right4個值之一,否則只會處于相對定位
3、父元素的高度不能低于sticky元素的高度
4、sticky元素僅在其父元素內生效,所以父元素必須是 mescroll

瀏覽器兼容性:

由于這是一個全新的屬性,以至于到現在都沒有一個規范,W3C也剛剛開始討論它,而現在只有webkit nightly版本和chrome 開發版(Chrome 23.0.1247.0+ Canary)才開始支持它。

另外需要注意的是,如果同時定義了left和right值,那么left生效,right會無效,同樣,同時定義了top和bottom,top贏~~

fall back

雖然其它瀏覽器尚不支持,但是實現起來其實不難,我們可以用js簡單實現:

HTML

<div class="header"></div>

CSS

.sticky {position: fixed;top: 0; } .header {width: 100%;background: #f6d565;padding: 25px 0; }

JS

var header = document.querySelector('.header'); var origOffsetY = header.offsetTop; function onScroll(e) {window.scrollY >= origOffsetY ? header.classList.add('sticky') : header.classList.remove('sticky'); } document.addEventListener('scroll', onScroll);

這里是一個簡單的demo。

嗯,對于前端來說,新技術用于提升用戶體驗才能體現其價值~~

本文轉載,原文來源于:https://www.qianduan.net/position-sticky-introduction/

總結

以上是生活随笔為你收集整理的position:sticky介绍的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。