JS实现导航栏楼层特效


Posted in Javascript onJanuary 01, 2020

本文实例为大家分享了JS实现导航栏楼层的具体代码,供大家参考,具体内容如下

知识点

1.多个事件有冲突的时候,需要设置flag判断是什么事件,进而进行后续操作。
2.楼层效果就是判断scrollTop和offsetTop的关系
3.引入工具库工具库

运行效果

导航与界面实现互动

JS实现导航栏楼层特效

JS实现导航栏楼层特效

代码

<!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>
  <!--导航-->
  <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层内容</li>
    <li>第2层内容</li>
    <li>第3层内容</li>
    <li>第4层内容</li>
    <li>第5层内容</li>
  </ul>

<script src="../../00MyTools/MyTools.js"></script>
<script>
  window.addEventListener('load', function (ev) {
     // 1. 获取标签
    var ol = myTool.$('ol'), ul = myTool.$('ul');
    var ulLis = ul.children;
    var olLis = ol.children;

    // 是否是点击产生的滚动
    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. 监听导航点击
    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. 监听滚动
    var roll = 0;
    window.addEventListener('scroll', function (ev1) {
      if(!isClick){
        // 4.1 获取头部滚动偏移的高度
        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>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript多种数据类型表格排序代码分析
Sep 11 Javascript
往光标所在位置插入值的js代码
Sep 22 Javascript
JS嵌套函数调用上下文的问题解决
Mar 26 Javascript
百度地图api如何使用
Aug 03 Javascript
你知道setTimeout是如何运行的吗?
Aug 16 Javascript
微信小程序 scroll-view组件实现列表页实例代码
Dec 14 Javascript
引入外部js脚本加载慢与页面白屏问题的解决
Dec 10 Javascript
微信小程序使用setData修改数组中单个对象的方法分析
Dec 30 Javascript
微信小程序获取用户信息并保存登录状态详解
May 10 Javascript
vue+eslint+vscode配置教程
Aug 09 Javascript
Vue仿百度搜索功能
Dec 28 Vue.js
vue调用微信JSDK 扫一扫,相册等需要注意的事项
Jan 03 Vue.js
JS实现旋转木马轮播图
Jan 01 #Javascript
JS实现普通轮播图特效
Jan 01 #Javascript
javascript实现超好看的3D烟花特效
Jan 01 #Javascript
JavaScript工具库MyTools详解
Jan 01 #Javascript
javascript Canvas动态粒子连线
Jan 01 #Javascript
小程序新版订阅消息模板消息
Dec 31 #Javascript
小程序实现长按保存图片的方法
Dec 31 #Javascript
You might like
php 一元分词算法
2009/11/30 PHP
Smarty模板变量调节器用法分析
2016/05/23 PHP
php5.2的curl-bug 服务器被php进程卡死问题排查
2016/09/19 PHP
php设计模式之工厂模式用法经典实例分析
2019/09/20 PHP
Dojo 学习笔记入门篇 First Dojo Example
2009/11/15 Javascript
Jquery倒数计时按钮setTimeout的实例代码
2013/07/04 Javascript
解析JavaScript的ES6版本中的解构赋值
2015/07/28 Javascript
深入理解JavaScript内置函数
2016/06/03 Javascript
用JS实现轮播图效果(二)
2016/06/26 Javascript
javascript 中的事件委托详解
2016/10/25 Javascript
Bootstrap Img 图片样式(推荐)
2016/12/13 Javascript
vue使用echarts图表的详细方法
2018/10/22 Javascript
基于React Native 0.52实现轮播图效果
2020/08/25 Javascript
JS高阶函数原理与用法实例分析
2019/01/15 Javascript
JavaScript中十种一步拷贝数组的方法实例详解
2019/04/22 Javascript
vue实现路由监听和参数监听
2019/10/29 Javascript
微信小程序利用云函数获取手机号码
2019/12/17 Javascript
JavaScript计算出两个数的差值
2020/03/19 Javascript
vue使用map代替Aarry数组循环遍历的方法
2020/04/30 Javascript
vscode 调试 node.js的方法步骤
2020/09/15 Javascript
JavaScript中的Proxy对象
2020/11/27 Javascript
在vue中使用inheritAttrs实现组件的扩展性介绍
2020/12/07 Vue.js
Python中的defaultdict模块和namedtuple模块的简单入门指南
2015/04/01 Python
在python中使用正则表达式查找可嵌套字符串组
2017/10/24 Python
详解python中的Turtle函数库
2018/11/19 Python
对django xadmin自定义菜单的实例详解
2019/01/03 Python
python向字符串中添加元素的实例方法
2019/06/28 Python
python爬虫 线程池创建并获取文件代码实例
2019/09/28 Python
Python猴子补丁知识点总结
2020/01/05 Python
python dumps和loads区别详解
2020/02/04 Python
下面关于"联合"的题目的输出是什么
2013/08/06 面试题
兰兰过桥教学反思
2014/02/08 职场文书
创建文明城市倡议书
2015/04/28 职场文书
技术入股合作协议书
2016/03/21 职场文书
mysql 联合索引生效的条件及索引失效的条件
2021/11/20 MySQL
Mysql事务索引知识汇总
2022/03/17 MySQL