js實現(xiàn)樓層導(dǎo)航功能
圖如下所示:

1.點(diǎn)擊跳轉(zhuǎn)到相應(yīng)區(qū)域:
頁面scroll掉的距離 = 目標(biāo)板塊在文檔中的垂直坐標(biāo) - 起始板塊(目標(biāo)位置)到視圖頂部的距離;
document.body.scrollTop = scrollLength; document.documentElement.scrollTop = scrollLength;
2.滾動滾動條時對應(yīng)的導(dǎo)航鏈接被激活
每個板塊的導(dǎo)航鏈接對應(yīng)一個長度區(qū)間,當(dāng)滾動條滾動調(diào)的長度落在該區(qū)間時,該導(dǎo)航條則被選中。區(qū)間范圍為當(dāng)前板塊的scrollTop值(包含)~下一板塊的ScrollTop值(不包含)。
例如:第一板塊的區(qū)間為0~第二板塊的scrollTop值(即第一板塊的高度),當(dāng)滾動條滾動的距離落在該區(qū)間時,則第一個鏈接激活。
如何確定區(qū)間?將鏈接倒敘排列,依次循環(huán)判斷,第一個(滾動條滾動的距離>區(qū)間最小值)成立的鏈接即為激活鏈接。
var currIndex=0;
window.onscroll = function () {
var $cptop = $('.cp-top');
var scrollLength = document.documentElement.scrollTop || document.body.scrollTop; //滾動條滾動的距離
var list_area = _.map($('#area li.group'), function (item, index) {
return { top: item.offset().top, index: index };
}); //所有的板塊
list_area = _.sortBy(list, function (item) { return -item.index; }); //倒序
var reachedArea = _.find(list_area, function (item) {
return scrollLength >= item.top;
}); //滾動的距離大于該區(qū)間的最小top值
if (currIndex != reachedArea.index) {
currIndex = reachedArea.index;
$(".navField li").removeClass('selected');
$(".navField li").eq(reachedField.index).addClass('selected');
}
}
以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時也希望多多支持腳本之家!
相關(guān)文章
Javascript點(diǎn)擊按鈕隨機(jī)改變數(shù)字與其顏色
這篇文章主要介紹了Javascript點(diǎn)擊按鈕隨機(jī)改變數(shù)字和其字體的顏色,實現(xiàn)后的效果很不錯,具有一定的參考價值,有需要的可以參考借鑒,下面來一起看看。2016-09-09
JavaScript前端實現(xiàn)GIF圖片循環(huán)播放
使用 img 加載 GIF 圖片,內(nèi)容只會播放一次,之后就會自動暫停,所以這篇文章為大家介紹了如何使用JavaScript實現(xiàn)GIF圖片循環(huán)播放吧2025-03-03
JavaScript實現(xiàn)三級聯(lián)動菜單實例代碼
這篇文章主要為大家詳細(xì)介紹了JavaScript實現(xiàn)三級聯(lián)動菜單實例代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-06-06
JavaScript實現(xiàn)合并(歸并)排序算法示例解析
這篇文章主要為大家介紹了JavaScript實現(xiàn)合并(歸并)排序算法示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08
javascript一個判斷瀏覽器類型的函數(shù)(類)
javascript一個判斷瀏覽器類型的函數(shù)(類)...2007-08-08

