欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS電梯導(dǎo)航的實(shí)現(xiàn)示例

 更新時(shí)間:2023年05月06日 15:56:02   作者:Mr-Wang-Y-P  
本文主要介紹了JS電梯導(dǎo)航的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

預(yù)覽效果

之前css 利用 scroll-behavior 和 錨點(diǎn) 實(shí)現(xiàn)了 電梯導(dǎo)航,點(diǎn)擊可以看這篇文章css實(shí)現(xiàn)電梯導(dǎo)航的效果。評(píng)論區(qū)有人想讓我用js也實(shí)現(xiàn)一下,一開始我起初有點(diǎn)蒙,不知道css和js實(shí)現(xiàn)的效果有什么區(qū)別。后來我發(fā)現(xiàn)了。

css實(shí)現(xiàn)的只是單純點(diǎn)擊滑動(dòng)到指定位置而已。而js實(shí)現(xiàn)不僅可以實(shí)現(xiàn)點(diǎn)擊滑動(dòng),而且可以監(jiān)聽滑動(dòng)事件,讓滑動(dòng)標(biāo)題高亮,也就是有一個(gè)active

比如我們?cè)谶@里滑倒了第一塊區(qū)域的末尾,但是還沒滑倒第二塊區(qū)域,于是滑動(dòng)標(biāo)題還只是Section1高亮,當(dāng)我們滑動(dòng)到第二塊區(qū)域時(shí),滑動(dòng)標(biāo)題變成了Section2高亮

image.png

image.png

主要的js代碼

主要思路就是對(duì)滑動(dòng)事件進(jìn)行監(jiān)聽。監(jiān)聽到當(dāng)前滑動(dòng)到的位置,然后判斷當(dāng)前所在的位置處于哪一塊區(qū)域。給它add active的類,當(dāng)滑走當(dāng)前區(qū)域,就會(huì)remove active類。

監(jiān)聽點(diǎn)擊事件,其實(shí)跟css 里的scroll-behavior差不多。點(diǎn)擊導(dǎo)航,然后獲取點(diǎn)擊的href,然后獲取要顯示的區(qū)域的位置,然后滑動(dòng)到那個(gè)位置,然后導(dǎo)航就會(huì)運(yùn)行上面的監(jiān)聽加高亮類。

 // 獲取所有的導(dǎo)航鏈接
        const links = document.querySelectorAll('.elevator a');
        // 獲取所有的內(nèi)容區(qū)塊
        const sections = document.querySelectorAll('.section');
        // 監(jiān)聽窗口滾動(dòng)事件
        window.addEventListener('scroll', function () {
            // 獲取滾動(dòng)條的位置
            const scrollTop = document.documentElement.scrollTop || document.body.scrollTop;
            // 遍歷所有的內(nèi)容區(qū)塊
            sections.forEach(function (section) {
                // 獲取內(nèi)容區(qū)塊的位置信息
                const offsetTop = section.offsetTop;
                const offsetHeight = section.offsetHeight;
                // 判斷當(dāng)前內(nèi)容區(qū)塊是否在可視范圍內(nèi)
                if (scrollTop >= offsetTop && scrollTop < offsetTop + offsetHeight) {
                    // 如果在可視范圍內(nèi),則將對(duì)應(yīng)的導(dǎo)航鏈接設(shè)置為 active 狀態(tài)
                    links.forEach(function (link) {
                        if (link.getAttribute('href') === '#' + section.getAttribute('id')) {
                            link.classList.add('active');
                        } else {
                            link.classList.remove('active');
                        }
                    });
                }
            });
        });
        // 監(jiān)聽所有的導(dǎo)航鏈接的點(diǎn)擊事件
        links.forEach(function (link) {
            link.addEventListener('click', function (event) {
                event.preventDefault();
                // 獲取目標(biāo)內(nèi)容區(qū)塊的位置信息
                const targetId = link.getAttribute('href');
                const targetSection = document.querySelector(targetId);
                const targetOffsetTop = targetSection.offsetTop;
                // 使用動(dòng)畫滑動(dòng)到目標(biāo)內(nèi)容區(qū)塊
                window.scrollTo({
                    top: targetOffsetTop,
                    behavior: 'smooth'
                });
            });
        });

整體代碼

html

  • 導(dǎo)航 一個(gè)ul標(biāo)簽里面五個(gè)li 點(diǎn)擊事件
  • 頁(yè)面顯示 五個(gè)塊級(jí)區(qū)域
  <div class="elevator">
        <ul>
            <li><a href="#section1" rel="external nofollow" >Section 1</a></li>
            <li><a href="#section2" rel="external nofollow" >Section 2</a></li>
            <li><a href="#section3" rel="external nofollow" >Section 3</a></li>
            <li><a href="#section4" rel="external nofollow" >Section 4</a></li>
            <li><a href="#section5" rel="external nofollow" >Section 5</a></li>
        </ul>
    </div>
    <div class="section" id="section1">
        <h2>Section 1</h2>
        <p>第一塊 </p>
        <video
            src="https://img-baofun.zhhainiao.com/pcwallpaper_ugc/preview/2366564fa6b83158208eb3181752a8d6_preview.mp4"
            autoplay muted loop></video>
    </div>
    <div class="section" id="section2">
        <h2>Section 2</h2>
        <p>第二塊 </p>
        <video src="https://img-baofun.zhhainiao.com/market/133/3760b2031ff41ca0bd80bc7a8a13f7bb_preview.mp4" autoplay
            muted loop></video>
    </div>
    <div class="section" id="section3">
        <h2>Section 3</h2>
        <p>第三塊 </p>
        <video src="https://img-baofun.zhhainiao.com/market/semvideo/3fc6cdef4427e61be69096c6ebb59a1c_preview.mp4"
            autoplay muted loop></video>
    </div>
    <div class="section" id="section4">
        <h2>Section 4</h2>
        <p>第四塊 </p>
        <video src="https://img-baofun.zhhainiao.com/market/semvideo/6ac24b3f50fda0b1a55f7ff25c6b62af_preview.mp4"
            autoplay muted loop></video>
    </div>
    <div class="section" id="section5">
        <h2>Section 5</h2>
        <p>第五塊 </p>
        <video src="https://img-baofun.zhhainiao.com/market/133/97ba6b60662ab4f31ef06cdf5a5f8e94_preview.mp4" autoplay
            muted loop></video>
    </div>

css

.elevator 固定電梯按鈕,也就是導(dǎo)航

.elevator {
    position: fixed; /* 固定定位,保證電梯一直在頁(yè)面可視區(qū)域內(nèi) */
    top: 50%; /* 在頁(yè)面垂直居中 */
    right: 0; /* 在頁(yè)面右側(cè) */
    transform: translateY(-50%); /* 通過 translateY 屬性來調(diào)整位置,保證垂直居中 */
}
.elevator ul {
    list-style: none; /* 去掉列表樣式 */
    margin: 0; /* 去掉外邊距 */
    padding: 0; /* 去掉內(nèi)邊距 */
}
.elevator li {
    margin: 10px 0; /* 設(shè)置每個(gè)列表項(xiàng)的上下外邊距 */
}
.elevator a {
    display: block; /* 將鏈接轉(zhuǎn)換為塊級(jí)元素,方便設(shè)置樣式 */
    padding: 10px; /* 設(shè)置內(nèi)邊距 */
    background-color: #ccc; /* 設(shè)置背景顏色 */
    color: #000; /* 設(shè)置文字顏色 */
    text-decoration: none; /* 去掉下劃線 */
}
.elevator a.active {
    background-color: #000; /* 當(dāng)前所在樓層鏈接的背景顏色 */
    color: #fff; /* 當(dāng)前所在樓層鏈接的文字顏色 */
}
/* 頁(yè)面區(qū)塊樣式 */
.section {
    width: 90vw; /* 頁(yè)面寬度為視口寬度的90% */
    height: 110vh; /* 頁(yè)面高度為視口高度的110% */
}
.section video {
    width: 100%; /* 視頻寬度自適應(yīng)父級(jí)容器 */
    height: 90%; /* 視頻高度為父級(jí)容器高度的90% */
}

js

就是之前的主要的js代碼

到此這篇關(guān)于JS電梯導(dǎo)航的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)JS電梯導(dǎo)航內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • JS數(shù)組方法shift()、unshift()用法實(shí)例分析

    JS數(shù)組方法shift()、unshift()用法實(shí)例分析

    這篇文章主要介紹了JS數(shù)組方法shift()、unshift()用法,結(jié)合實(shí)例形式分析了JavaScript數(shù)組shift()與unshift()方法功能、用法及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下
    2020-01-01
  • javascript淡入淡出效果的實(shí)現(xiàn)思路

    javascript淡入淡出效果的實(shí)現(xiàn)思路

    這個(gè)思路是最近寫XScroll.js類的時(shí)候想明白的。平常我們說的淡入淡出效果,一般分成兩部分,一半是淡入,另一半就是淡出了。不過經(jīng)過分析,我覺得其實(shí)只需要一半就行了
    2012-03-03
  • 修改layui的后臺(tái)模板的左側(cè)導(dǎo)航欄可以伸縮的方法

    修改layui的后臺(tái)模板的左側(cè)導(dǎo)航欄可以伸縮的方法

    今天小編就為大家分享一篇修改layui的后臺(tái)模板的左側(cè)導(dǎo)航欄可以伸縮的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • JS獲取數(shù)組中出現(xiàn)次數(shù)最多及第二多元素的方法

    JS獲取數(shù)組中出現(xiàn)次數(shù)最多及第二多元素的方法

    這篇文章主要介紹了JS獲取數(shù)組中出現(xiàn)次數(shù)最多及第二多元素的方法,涉及javascript針對(duì)數(shù)組的遍歷、排序、判斷、查詢等相關(guān)操作技巧,需要的朋友可以參考下
    2017-10-10
  • 微信小程序頁(yè)面縮放式側(cè)滑效果的實(shí)現(xiàn)代碼

    微信小程序頁(yè)面縮放式側(cè)滑效果的實(shí)現(xiàn)代碼

    這篇文章主要介紹了微信小程序頁(yè)面縮放式側(cè)滑效果的實(shí)現(xiàn)代碼,實(shí)現(xiàn)原理就是通過點(diǎn)擊按鈕,往需要?jiǎng)赢嫷膁iv中添加或移除擁有動(dòng)畫效果的class。具體實(shí)例代碼大家跟隨小編一起通過本文學(xué)習(xí)吧
    2018-11-11
  • javascript動(dòng)畫算法實(shí)例分析

    javascript動(dòng)畫算法實(shí)例分析

    這篇文章主要介紹了javascript動(dòng)畫算法,實(shí)例分析了javascript實(shí)現(xiàn)動(dòng)畫效果的實(shí)現(xiàn)及使用技巧,需要的朋友可以參考下
    2015-07-07
  • uni-app?web-view的使用示例詳解

    uni-app?web-view的使用示例詳解

    這篇文章主要介紹了uni-app web-view的使用,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-07-07
  • js字符串與Unicode編碼互相轉(zhuǎn)換

    js字符串與Unicode編碼互相轉(zhuǎn)換

    本文主要介紹了js字符串與Unicode編碼互相轉(zhuǎn)換的相關(guān)知識(shí)。具有很好的參考價(jià)值。下面跟著小編一起來看下吧
    2017-05-05
  • 防止登錄頁(yè)面出現(xiàn)在frame中js代碼

    防止登錄頁(yè)面出現(xiàn)在frame中js代碼

    使用frame頁(yè)面嵌套,重啟了服務(wù)器的時(shí)候會(huì)出現(xiàn)登錄頁(yè)面在frame頁(yè)面中出現(xiàn),解決方法是在登錄頁(yè)面里面用js判斷下當(dāng)前的地址信息
    2014-07-07
  • 解析js原生方法創(chuàng)建表格效率測(cè)試

    解析js原生方法創(chuàng)建表格效率測(cè)試

    對(duì)于創(chuàng)建表格本文提到的算法共有3種,分別是直接操作dom、借助createDocumentFragment、借助js的原生表格操作方法
    2013-07-07

最新評(píng)論