亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JS實(shí)現(xiàn)導(dǎo)航欄樓層特效

 更新時(shí)間:2020年01月01日 13:03:56   作者:KaiSarH  
這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)導(dǎo)航欄樓層特效,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了JS實(shí)現(xiàn)導(dǎo)航欄樓層的具體代碼,供大家參考,具體內(nèi)容如下

知識點(diǎn)

1.多個(gè)事件有沖突的時(shí)候,需要設(shè)置flag判斷是什么事件,進(jìn)而進(jìn)行后續(xù)操作。
2.樓層效果就是判斷scrollTop和offsetTop的關(guān)系
3.引入工具庫工具庫

運(yùn)行效果

導(dǎo)航與界面實(shí)現(xiàn)互動(dòng)

代碼

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Title</title>
  <style>
    *{margin: 0;padding: 0;list-style: none;border:0;}
    html, body, ul{width: 100%;height: 100%;}
    #ul li{
      width: 100%;
      height: 100%;
      text-align: center;
      font-size: 30px;
      /*background-color: red;*/
      color: #fff;
    }

    #ol{
      width: 80px;
      background-color: #ccc;
      position: fixed;
      left: 50px;
      top: 200px;
      border: 1px solid #fff;
    }

    #ol li{
      text-align: center;
      line-height: 30px;
      border-bottom: 1px solid #fff;
      color: #fff;
      cursor: pointer;
    }

    #ol li.current{
      background-color: orangered;
    }
  </style>
</head>
<body>
  <!--導(dǎo)航-->
  <ol id="ol">
    <li class="current">第1層</li>
    <li>第2層</li>
    <li>第3層</li>
    <li>第4層</li>
    <li>第5層</li>
  </ol>
  <!--樓層-->
  <ul id="ul">
    <li>第1層內(nèi)容</li>
    <li>第2層內(nèi)容</li>
    <li>第3層內(nèi)容</li>
    <li>第4層內(nèi)容</li>
    <li>第5層內(nèi)容</li>
  </ul>

<script src="../../00MyTools/MyTools.js"></script>
<script>
  window.addEventListener('load', function (ev) {
     // 1. 獲取標(biāo)簽
    var ol = myTool.$('ol'), ul = myTool.$('ul');
    var ulLis = ul.children;
    var olLis = ol.children;

    // 是否是點(diǎn)擊產(chǎn)生的滾動(dòng)
    var isClick = false;

    // 2. 上色
    var colorArr = ['red', 'green', 'blue', 'purple', 'yellow'];
    for (var i = 0; i < colorArr.length; i++) {
      ulLis[i].style.backgroundColor = colorArr[i];
    }

    // 3. 監(jiān)聽導(dǎo)航點(diǎn)擊
    for (var j = 0; j < olLis.length; j++) {
      var olLi = olLis[j];
      (function (index) {
        olLi.addEventListener('click', function () {
          isClick = true;
          for (var i = 0; i < olLis.length; i++) {
            olLis[i].className = '';
          }
          this.className = 'current';
          // document.documentElement.scrollTop = index * myTool.client().height;

          myTool.slowMoving(document.documentElement, {'scrollTop': index * myTool.client().height}, function () {
            isClick = false;
          });
        });
      })(j)
    }

    // 4. 監(jiān)聽滾動(dòng)
    var roll = 0;
    window.addEventListener('scroll', function (ev1) {
      if(!isClick){
        // 4.1 獲取頭部滾動(dòng)偏移的高度
        roll = Math.ceil(Number(myTool.scroll().top));

        // 4.2 遍歷
        for (var i = 0; i < ulLis.length; i++) {
          // 4.3 判斷
          if(roll >= ulLis[i].offsetTop){
            for (var j = 0; j < olLis.length; j++) {
              olLis[j].className = '';
            }
            olLis[i].className = 'current';
          }
        }
      }
    })
  });
</script>
</body>
</html>

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • iframe與主框架跨域相互訪問實(shí)現(xiàn)方法

    iframe與主框架跨域相互訪問實(shí)現(xiàn)方法

    今天正好需要用到iframe 與主框架相互訪問的實(shí)現(xiàn)方法,正好看到了這篇文章,確實(shí)不錯(cuò),特分享一下,需要的朋友可以參考下
    2017-09-09
  • JS實(shí)現(xiàn)簡單拖拽效果

    JS實(shí)現(xiàn)簡單拖拽效果

    這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)拖拽效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • JavaScript變量基本使用方法實(shí)例分析

    JavaScript變量基本使用方法實(shí)例分析

    這篇文章主要介紹了JavaScript變量基本使用方法,結(jié)合實(shí)例形式分析了JavaScript變量的類型、使用注意事項(xiàng)及命名規(guī)范,需要的朋友可以參考下
    2019-11-11
  • JavaScript中實(shí)現(xiàn)數(shù)組分組功能的方法詳解

    JavaScript中實(shí)現(xiàn)數(shù)組分組功能的方法詳解

    最近,JavaScript引入了一個(gè)備受期待的功能:原生支持?jǐn)?shù)組分組,這一特性使得在處理復(fù)雜的數(shù)據(jù)集時(shí)變得更加簡單和高效,本文將深入探討這一全新的JavaScript特性,希望對大家有所幫助
    2023-12-12
  • js實(shí)現(xiàn)多個(gè)標(biāo)題吸頂效果

    js實(shí)現(xiàn)多個(gè)標(biāo)題吸頂效果

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)多個(gè)標(biāo)題吸頂效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-01-01
  • javascript計(jì)時(shí)器詳解

    javascript計(jì)時(shí)器詳解

    這篇文章主要詳細(xì)介紹了javascript計(jì)時(shí)器的相關(guān)資料,十分全面詳盡,需要的朋友可以參考下
    2015-02-02
  • .NET微信公眾號開發(fā)之創(chuàng)建自定義菜單

    .NET微信公眾號開發(fā)之創(chuàng)建自定義菜單

    這篇文章主要介紹了.NET微信公眾號開發(fā)之創(chuàng)建自定義菜單的相關(guān)資料,需要的朋友可以參考下
    2015-07-07
  • promise結(jié)合requestAnimationFrame用法示例

    promise結(jié)合requestAnimationFrame用法示例

    這篇文章主要為大家介紹了promise結(jié)合requestAnimationFrame用法示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • 淺談小程序 setData學(xué)問多

    淺談小程序 setData學(xué)問多

    這篇文章主要介紹了淺談小程序 setData學(xué)問多,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2019-02-02
  • javascript實(shí)現(xiàn)留言板功能

    javascript實(shí)現(xiàn)留言板功能

    這篇文章主要為大家詳細(xì)介紹了javascript實(shí)現(xiàn)留言板功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-02-02

最新評論