Javascript實(shí)現(xiàn)頁面滾動(dòng)時(shí)導(dǎo)航智能定位
常見的開發(fā)頁面中可能會(huì)有這么一個(gè)需求,頁面中會(huì)有多個(gè)模塊,每個(gè)模塊對應(yīng)一個(gè)導(dǎo)航,當(dāng)頁面滾動(dòng)到某個(gè)模塊時(shí),對應(yīng)的模塊導(dǎo)航需要加上一個(gè)類用于區(qū)分當(dāng)前用戶所瀏覽區(qū)域。
假設(shè)結(jié)構(gòu)如下:
<div class="container"> <div class="wrapper"> <div class="section" id="section1">section1</div> <div class="section" id="section2">section2</div> <div class="section" id="section3">section3</div> <div class="section" id="section4">section4</div> <div class="section" id="section5">section5</div> </div> <nav> <a href="#section1" rel="external nofollow" class="current">section1</a> <a href="#section2" rel="external nofollow" >section2</a> <a href="#section3" rel="external nofollow" >section3</a> <a href="#section4" rel="external nofollow" >section4</a> <a href="#section5" rel="external nofollow" >section5</a> </nav> </div>
頁面滾動(dòng)時(shí)導(dǎo)航定位
js代碼如下:
var $navs = $('nav a'), // 導(dǎo)航 $sections = $('.section'), // 模塊 $window = $(window), navLength = $navs.length - 1; $window.on('scroll', function() { var scrollTop = $window.scrollTop(), len = navLength; for (; len > -1; len--) { var that = $sections.eq(len); if (scrollTop >= that.offset().top) { $navs.removeClass('current').eq(len).addClass('current'); break; } } });
效果如下:
不難看出,基本原理就是在window滾動(dòng)的時(shí)候,依次將模塊從后向前遍歷,如果window的滾動(dòng)高度大于或等于當(dāng)前模塊的距頁面頂部的距離,則將當(dāng)前模塊對應(yīng)的導(dǎo)航突出顯示,并且不再繼續(xù)遍歷
點(diǎn)擊導(dǎo)航定位頁面
除了這種需求外,還有另一種需求,就是點(diǎn)擊導(dǎo)航定位到導(dǎo)航所對應(yīng)模塊的頂部。
代碼如下:
$navs.on('click', function(e) { e.preventDefault(); $('html, body').animate({ 'scrollTop': $($(this).attr('href')).offset().top }, 400); });
效果如下:
以上基本上滿足了業(yè)務(wù)的基本需求,這是工作中總結(jié)的經(jīng)驗(yàn),希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- js阻止移動(dòng)端頁面滾動(dòng)的兩種方法
- 解決js頁面滾動(dòng)效果scrollTop在FireFox與Chrome瀏覽器間的兼容問題的方法
- js網(wǎng)頁側(cè)邊隨頁面滾動(dòng)廣告效果實(shí)現(xiàn)
- 基于AngularJS實(shí)現(xiàn)頁面滾動(dòng)到底自動(dòng)加載數(shù)據(jù)的功能
- js實(shí)現(xiàn)的鼠標(biāo)滾輪滾動(dòng)切換頁面效果(類似360默認(rèn)頁面滾動(dòng)切換效果)
- js頁面滾動(dòng)時(shí)層智能浮動(dòng)定位實(shí)現(xiàn)(jQuery/MooTools)
- JavaScript實(shí)現(xiàn)頁面滾動(dòng)圖片加載(仿lazyload效果)
- 原生Js頁面滾動(dòng)延遲加載圖片實(shí)現(xiàn)原理及過程
- JS實(shí)現(xiàn)隨頁面滾動(dòng)顯示/隱藏窗口固定位置元素
- 原生js實(shí)現(xiàn)頁面滾動(dòng)動(dòng)畫
相關(guān)文章
第七篇Bootstrap表單布局實(shí)例代碼詳解(三種表單布局)
Bootstrap提供了三種表單布局:垂直表單,內(nèi)聯(lián)表單和水平表單。接下來通過本文給大家介紹Bootstrap表單布局實(shí)例代碼詳解,非常不錯(cuò),具有參考借鑒價(jià)值,感興趣的朋友一起學(xué)習(xí)吧2016-06-06基于css3新屬性transform及原生js實(shí)現(xiàn)鼠標(biāo)拖動(dòng)3d立方體旋轉(zhuǎn)
這篇文章主要介紹了基于css3新屬性transform及原生js實(shí)現(xiàn)鼠標(biāo)拖動(dòng)3d立方體旋轉(zhuǎn) 的相關(guān)資料,需要的朋友可以參考下2016-06-06百度判斷手機(jī)終端并自動(dòng)跳轉(zhuǎn)js代碼及使用實(shí)例
這篇文章主要介紹了百度判斷手機(jī)終端并自動(dòng)跳轉(zhuǎn)js代碼及使用實(shí)例,需要的朋友可以參考下2014-06-06js統(tǒng)計(jì)錄入文本框中字符的個(gè)數(shù)并加以限制不超過多少
為了更直觀的體現(xiàn)用戶在文本框輸入文本時(shí)能看到自己輸入了多少字,并且有些特殊的要求字?jǐn)?shù)不超過多少,本文給出了具體的實(shí)現(xiàn)2014-05-05Bootstrap基本組件學(xué)習(xí)筆記之input輸入框組(9)
這篇文章主要為大家詳細(xì)介紹了Bootstrap基本組件學(xué)習(xí)筆記之input輸入框組,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-12-12淺談webpack打包過程中因?yàn)閳D片的路徑導(dǎo)致的問題
下面小編就為大家分享一篇淺談webpack打包過程中因?yàn)閳D片的路徑導(dǎo)致的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-02-02