亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > CSS > 正文

CSS scroll-snap滾動事件停止及元素位置檢測實現

2024-07-11 09:00:00
字體:
來源:轉載
供稿:網友

一、Scroll Snap是前端必備技能

CSS Scroll Snap是個非常好用的特性,可以讓網頁容器滾動停止的時候,無需任何JS代碼的參與,瀏覽器可以自動平滑定位到指定元素的指定位置。類似幻燈片廣告效果就可以純CSS實現。

而且CSS Scroll Snap的兼容性非常好,移動端幾乎可以放心使用。

 

二、源自實際項目的scroll-snap場景

今天下午在實現一個功能需求的時候,正好遇到一個場景非常適合使用Scroll Snap來實現,滑動依次顯示人物角色。于是就大膽使用了下,哇,好棒,無需任何js做邊界判斷,滑動停止自動定位到想要的位置。

關鍵CSS代碼如下:

ul {    width: 375px; height: 667px;    scroll-snap-type: x mandatory;    -webkit-overflow-scrolling: touch;    white-space: nowrap;    overflow-y: hidden;    }li {    display: inline-block;    width: 100%; height: 100%;    scroll-snap-align: center;}

滾動父容器元素設置 scroll-snap-type:x mandatory ,水平滾動,強制定位,子列表元素設置 scroll-snap-align:center 讓列表在滾動容器的中間顯示,于是效果達成。

然而,滾動定位結束后,還需要需要高亮當前定位的人物素材。我發現有些難辦了!

以前這種滑動效果用JS實現,無論是JS動畫結束,還是CSS動畫結束,都是有回調函數可以使用的。但是這里卻是滾動,而且滾動后還會自己再定位一會兒,自己定位時間有長有短,誰知道什么時候停止?有時候一口氣滑多個元素,也不確定到底停止在哪個元素上。

實際上,標準制定者們和瀏覽器廠商正在積極推進Scroll Snap相關回調事件的落地,這樣可以精確知道滾到什么時候停止以及滾動定位到哪個元素上,但是,標準還在折騰,瀏覽器還沒有支持。項目現在就要用,怎么辦呢?

對!肯定要出動JS輔助。

實際上,就算不是Scroll Snap的使用場景,就算是普通的滾動,由于滾動具有慣性,檢測滾動是否停止也是一個經常會遇到的需求。因此,有必要捋一個檢測滾動什么時候停止的方法。

三、我的滾動中止檢測方法

檢測元素的滾動是否停止,我的實現思路是這樣的,在滾動事件中跑一個定時器,記錄當前時間的滾動距離和上一次滾動的距離是否相等,如果相等則認為滾動已經停止,如果不相等,則認為滾動依然在進行。

用JavaScript示意就是( 這個實現已作廢 ):

// 定時器,用來檢測水平滾動是否結束var timer = null;// 上一次滾動的距離var scrollLeft = 0, scrollTop = 0;// 滾動事件開始container.addEventListener('scroll', function () {    clearInterval(timer);    // 重新新的定時器    timer = setInterval(function () {        if (container.scrollLeft == scrollLeft && container.scrollTop == scrollTop) {            // 滾動距離相等,認為停止滾動了            clearInterval(timer);            // ... 做你想做的事情,如回調處理        } else {            // 否則,依然記住上一次滾動位置            scrollLeft = container.scrollLeft;            scrollTop = container.scrollTop;        }    }, 100);});

如果你有興趣,可以對上面代碼進行進一步封裝。

更新于翌日

滾動終止檢測可以無需判斷前后滾動距離是否相等,因為無論是慣性還是Snap定位scroll事件也是持續觸發的。因此,可以直接這樣:

// 定時器,用來檢測水平滾動是否結束var timer = null;// 滾動事件開始container.addEventListener('scroll', function () {    clearTimeout(timer);    // 重新新的定時器    timer = setTimeout(function () {        // 無滾動事件觸發,認為停止滾動了        // ... 做你想做的事情,如回調處理    }, 100);});

當然,上面提供的方法并不是非常精準的中止檢測,因為Scroll Snap最后的重定位瀏覽器自身有個檢測,這個檢測事件,根據我的反復研究與測試,應該是 350ms (實際運行可能會略微大幾毫秒),遠比上面設置的 100ms 要大,因此,會有一次錯誤的冗余判斷,發生在Snap定位開始之前。

我想了想,這個問題無法避免,但也不是什么大問題??偛豢赡茉O置 400ms 檢測,延遲太高,體驗不一定好。

四、當前滾動目標元素檢測方法

原理如下,遍歷所有的列表元素,檢測列表元素的左邊緣相對于滾動容器左邊緣(如果是左對齊- scroll-snap-align:left )或中心(居中對齊)或右邊緣(右對齊)的位置。當然,如果列表元素尺寸和滾動容器尺寸一致,則左中右邊緣檢測都可以。

JS示意:

[].slice.call(container.children).forEach(function (ele, index) {    if (Math.abs(ele.getBoundingClientRect().left - container.getBoundingClientRect().left) < 10) {        // 此刻的ele元素就是當前定位的元素        // ... 你可以對ele做你想做的事情    } else {        // 此刻的ele元素不是當前定位的元素    }});

嚴格來講,應該計算是否等于 0 ,而不是小于 10 ,這里嘛,加了點容錯區間吧。

搞定了上面2個需要JS輔助的需求點,最終的效果就出來了。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91青草视频久久| 国产精品一区二区三区毛片淫片| 日韩美女激情视频| 久久不射电影网| 久久男人的天堂| 国产成人精品日本亚洲| 在线播放国产一区中文字幕剧情欧美| 91人成网站www| 国产在线不卡精品| 亚洲免费福利视频| 欧美午夜丰满在线18影院| 国产日韩亚洲欧美| 久久人人97超碰精品888| 国产一区二区欧美日韩| 久久成年人视频| 成人激情视频小说免费下载| 精品美女永久免费视频| 91在线观看免费网站| 中文字幕日韩欧美在线| 欧美另类99xxxxx| 777国产偷窥盗摄精品视频| 国自在线精品视频| 国产ts人妖一区二区三区| 精品精品国产国产自在线| 精品一区二区三区四区在线| 亚洲午夜激情免费视频| 国产精品夜色7777狼人| 久久精品国产亚洲精品| 国产精品69久久久久| 欧美久久精品一级黑人c片| 日韩av影片在线观看| 亚洲精品720p| 孩xxxx性bbbb欧美| 在线亚洲国产精品网| 欧美日韩一区二区在线播放| 日韩成人小视频| 97精品欧美一区二区三区| 欧美视频精品一区| zzijzzij亚洲日本成熟少妇| 国产精品午夜一区二区欲梦| 色婷婷综合成人av| 国产精品视频一区国模私拍| 日韩电影免费在线观看| 亚洲欧美国产精品久久久久久久| 伊是香蕉大人久久| 日本高清+成人网在线观看| 青青草原成人在线视频| 91在线无精精品一区二区| 久久久久久久91| 国产在线视频不卡| 久久亚洲春色中文字幕| 国产精品jvid在线观看蜜臀| 国产精品永久免费在线| 亚洲一区国产精品| 精品女厕一区二区三区| 欧美在线视频网站| 久久久久久av| 国产精品福利网| 亚洲国产女人aaa毛片在线| 色综合色综合久久综合频道88| 国产视频在线观看一区二区| 中文字幕亚洲综合| 久久伊人91精品综合网站| 狠狠色狠狠色综合日日五| 国产精品日韩欧美大师| 国产不卡精品视男人的天堂| 久久久视频免费观看| 韩国三级电影久久久久久| 福利视频一区二区| 日韩欧美国产免费播放| 精品久久久中文| 97视频在线观看免费高清完整版在线观看| 日本高清视频一区| 久久久久久九九九| 日韩成人激情视频| 亚洲成人黄色网| 欧美大片网站在线观看| 在线播放日韩av| 国产成人精品视频在线观看| 国产精品自产拍在线观看中文| 国产免费一区二区三区在线能观看| 国产精品jvid在线观看蜜臀| 亚洲女人天堂色在线7777| 亚洲综合小说区| 国产精品久久二区| 日本成人激情视频| 亚洲免费av电影| 清纯唯美亚洲激情| 欧美大荫蒂xxx| 国产成人综合精品| 亚洲第一页自拍| 久久亚洲国产成人| 日韩av在线免费播放| www.亚洲免费视频| 国产综合久久久久| 高清一区二区三区四区五区| 不卡中文字幕av| 精品久久久久久久久国产字幕| 国产精品a久久久久久| 亚洲性夜色噜噜噜7777| 欧美不卡视频一区发布| 精品国产户外野外| 国产一区红桃视频| 国产97在线亚洲| 最近日韩中文字幕中文| 亚洲sss综合天堂久久| 国产亚洲aⅴaaaaaa毛片| 亚洲老板91色精品久久| 欧美韩国理论所午夜片917电影| 日本人成精品视频在线| 久久久久国产一区二区三区| 中文字幕在线视频日韩| 国产a级全部精品| y97精品国产97久久久久久| 亚洲国产精品免费| 在线看日韩欧美| 亚洲视频电影图片偷拍一区| 国产91ⅴ在线精品免费观看| 国产色综合天天综合网| 国产区精品在线观看| 欧美国产视频一区二区| 亚洲视频在线免费看| 色视频www在线播放国产成人| 国产精品入口福利| 亚洲国产天堂久久国产91| 欧美激情视频三区| 亚洲午夜久久久久久久| 欧美综合国产精品久久丁香| 亚洲成人a**站| 欧美激情一区二区久久久| 国产97在线亚洲| 亚洲精品国产电影| 久久久精品久久| 97热精品视频官网| 欧美乱人伦中文字幕在线| 亚洲爱爱爱爱爱| 欧美激情精品久久久久| 日韩精品免费电影| 亚洲性生活视频| 最近2019好看的中文字幕免费| 欧美成人午夜激情在线| 亚洲第一区在线观看| 成人激情视频免费在线| 亚洲精品日韩激情在线电影| 亚洲国产精品嫩草影院久久| 精品福利在线看| 亚洲一级免费视频| 亚洲自拍中文字幕| 欧美夫妻性生活视频| 日韩毛片在线观看| 91色精品视频在线| 久久精品色欧美aⅴ一区二区| 久久伊人91精品综合网站| 欧美制服第一页| 欧美网站在线观看| 伊人久久免费视频| 久久影视电视剧免费网站清宫辞电视| 亚洲国产精品999| 亚洲第一精品夜夜躁人人躁| 亚洲欧美日韩在线高清直播| 日本成人激情视频| 久久久久久午夜| 91国在线精品国内播放| 川上优av一区二区线观看|