国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

JS實現網站樓層導航效果代碼實例

瀏覽:79日期:2024-05-03 16:37:38

壹 ❀ 引言

對于樓層導航而言,還有個重要的功能就是,隨著滾動條滾動,達到某層時得同步點亮樓層導航的小圖片。

由于我前面也說了不打算使用JQ,所以想著用JS去實現它,實現并不難,主要得弄清滾動滿足怎樣的條件才應該點亮對應樓層,我們先看看實現效果:

JS實現網站樓層導航效果代碼實例

貳 ❀ 實現思路

第一點,因為是由滾動觸發的樓層判斷,所以肯定離不開onscroll事件。

第二點,我們貌似要獲取每個樓層頂端距離視窗頂部的距離,隨著滾動條往下滾動,此距離會不斷縮小,當接近到某個距離時我們判定此樓層入畫,當然其它樓層都滿足此判定。

而JQ提供了一個offset().top方法能獲取這個值,js中只有一個offsetTop屬性,獲取的是距離自己最近position屬性為非static的祖先元素的距離,此距離不隨滾動條滾動而縮小。

當然我們有方法模擬計算出offset().top的值,但沒必要

這里我直接引用了我之前博客得到的結論:offset().top =offsetTop -scrollTop(offsetTop參考對象為根元素)。

為了方便理解,我們假設樓層壹頂端距離視窗頂端為0時,此時判定樓層壹入畫,即樓層導航中第一個按鈕應該被點亮。

JS實現網站樓層導航效果代碼實例

由于offset().top = offsetTop - scrollTop,此時樓層壹距離頂端已經為0,我們可以得出當樓層壹的offsetTop = scrollTop時,我們認定樓層壹入畫。

而當樓層貳入畫時,樓層貳的offsetTop也等于滾動條的距離,此時樓層壹自然會出畫:

JS實現網站樓層導航效果代碼實例

那么現在我們得到了判斷樓層入畫的條件,如果某個樓層的offsetTop屬性的值小于等于滾動條距離時(如果用等于條件過于苛刻,很難剛好滾動到這個距離點上),我們點亮對應樓層的導航logo。

為了讓效果更加自然,我們肯定不會真的讓某個樓層緊貼頂部時才判定它滿足條件,肯定是提前某個距離就判定滿足,所以真正的條件應該是offsetTop - 100(這個數字看自己感覺) <= scrollTop

你是否會有,樓層貳入畫時樓層壹依然滿足offsetTop<=scrollTop條件的疑惑?在JQ里面,我們給某個元素添加點亮class的同時,還會清除掉兄弟元素的該class。

所以在JS里面也是如此,我們利用滿足樓層的索引來控制樣式,而后者滿足條件的索引始終會覆蓋前面的索引,所以被點亮的永遠只有一個。

現在弄懂了思路,代碼就好些了,下面直接貼上了實現代碼:

叁 ❀ 實現代碼

HTML部分:

<div class='floor'> <div style='background: #ffb6b9'>壹</div> <div style='background: #fae3d9'>貳</div> <div style='background: #bbded6'>叁</div> <div style='background: #8ac6d1'>肆</div> <div style='background: #fff1ac'>伍</div></div><ul class='floorNav'> <li>壹</li> <li>貳</li> <li>叁</li> <li>肆</li> <li>伍</li></ul>

CSS部分:

* { padding: 0; margin: 0; list-style: none;}.floor>div { height: 900px; line-height: 900px; text-align: center; color: #fff; font-size: 40px;}.floorNav { width: 40px; height: 200px; position: fixed; right: 0; top: 0; bottom: 0; margin: auto; background: #ddd;}.floorNav>li { height: 40px; line-height: 40px; text-align: center; color: #fff;}.active { background: #e4393c; color: #fff;}

JS部分:

//獲取樓層let floors = document.querySelectorAll('.floor>div');//獲取樓層導航let floorNavs = document.querySelectorAll('.floorNav>li');//滾動監聽window.onscroll = function () { //獲取滾動條高度,兼容ie let scrollTop = document.documentElement.scrollTop || document.body.scrollTop; //符合點亮條件的樓層索引 let activeIndex; //樓層導航圖標點亮控制 floors.forEach((floor, index) => { //檢查各樓層頂端距離視窗頂端距離,如果滿足條件則修改樓層圖標 floor.offsetTop - 100 <= scrollTop ? activeIndex = index : null; }); //根據索引數設置樓層樣式 floorNavs.forEach((nav, index) => { index === activeIndex ? nav.classList.add(’active’) : nav.classList.remove(’active’); });};

需要注意的是,這里我使用了js中操作classList對象的add方法與remove方法,這兩個方法IE并不支持,因為我這邊是不需要考慮IE的,所以就任性了。

本文只是提供了一個樓層導航的思路,實現肯定不是很好,若有更佳的做法,歡迎留言討論,那么本文結束。

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

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 日本一区二区三区精品视频 | 在线观看国产精品日本不卡网 | 一本色道久久综合亚洲精品加 | 欧美 亚洲 丝袜 清纯 中文 | 2020国产精品 | 国产成人看片免费视频观看 | 神马我我不卡伦影视 | 一区二区三区中文 | 国产成年人视频 | 欧美一级特黄乱妇高清视频 | 欧美激情久久久久久久大片 | 久久精品一品道久久精品9 久久精品一区 | 97精品国产综合久久久久久欧美 | 中文字幕亚洲天堂 | 中文字幕在亚洲第一在线 | 欧美一级毛片日本 | 亚洲成年网 | 久久在线 | 99在线观看视频 | 日本在线视频播放 | 日本免费的一级绿象 | 日韩3级 | 日韩成人毛片高清视频免费看 | 盈盈性影院 | 日韩精品一区二区三区中文在线 | 人人公开免费超级碰碰碰视频 | 在线观看国产精品入口 | 免费99热在线观看 | 精品日本亚洲一区二区三区 | 毛片无码国产 | 国内精品久久久久影院不卡 | 久久影院一区二区三区 | 国产精品一区二区三区四区五区 | 亚洲美女视频免费 | 3d动漫精品成人一区二区三 | 色拍拍在精品视频69影院在线 | 亚洲精品国产精品国自产 | 国产农村一二三区 | 久久久久综合 | 久久久99视频 | 免费日本在线视频 |