Javascript實現(xiàn)頁面滾動時導(dǎo)航智能定位
常見的開發(fā)頁面中可能會有這么一個需求,頁面中會有多個模塊,每個模塊對應(yīng)一個導(dǎo)航,當頁面滾動到某個模塊時,對應(yīng)的模塊導(dǎo)航需要加上一個類用于區(qū)分當前用戶所瀏覽區(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ǎ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滾動的時候,依次將模塊從后向前遍歷,如果window的滾動高度大于或等于當前模塊的距頁面頂部的距離,則將當前模塊對應(yīng)的導(dǎo)航突出顯示,并且不再繼續(xù)遍歷
點擊導(dǎo)航定位頁面
除了這種需求外,還有另一種需求,就是點擊導(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)驗,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- js阻止移動端頁面滾動的兩種方法
- 解決js頁面滾動效果scrollTop在FireFox與Chrome瀏覽器間的兼容問題的方法
- js網(wǎng)頁側(cè)邊隨頁面滾動廣告效果實現(xiàn)
- 基于AngularJS實現(xiàn)頁面滾動到底自動加載數(shù)據(jù)的功能
- js實現(xiàn)的鼠標滾輪滾動切換頁面效果(類似360默認頁面滾動切換效果)
- js頁面滾動時層智能浮動定位實現(xiàn)(jQuery/MooTools)
- JavaScript實現(xiàn)頁面滾動圖片加載(仿lazyload效果)
- 原生Js頁面滾動延遲加載圖片實現(xiàn)原理及過程
- JS實現(xiàn)隨頁面滾動顯示/隱藏窗口固定位置元素
- 原生js實現(xiàn)頁面滾動動畫
相關(guān)文章
第七篇Bootstrap表單布局實例代碼詳解(三種表單布局)
Bootstrap提供了三種表單布局:垂直表單,內(nèi)聯(lián)表單和水平表單。接下來通過本文給大家介紹Bootstrap表單布局實例代碼詳解,非常不錯,具有參考借鑒價值,感興趣的朋友一起學習吧2016-06-06基于css3新屬性transform及原生js實現(xiàn)鼠標拖動3d立方體旋轉(zhuǎn)
這篇文章主要介紹了基于css3新屬性transform及原生js實現(xiàn)鼠標拖動3d立方體旋轉(zhuǎn) 的相關(guān)資料,需要的朋友可以參考下2016-06-06js統(tǒng)計錄入文本框中字符的個數(shù)并加以限制不超過多少
為了更直觀的體現(xiàn)用戶在文本框輸入文本時能看到自己輸入了多少字,并且有些特殊的要求字數(shù)不超過多少,本文給出了具體的實現(xiàn)2014-05-05Bootstrap基本組件學習筆記之input輸入框組(9)
這篇文章主要為大家詳細介紹了Bootstrap基本組件學習筆記之input輸入框組,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-12-12淺談webpack打包過程中因為圖片的路徑導(dǎo)致的問題
下面小編就為大家分享一篇淺談webpack打包過程中因為圖片的路徑導(dǎo)致的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-02-02