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 SocialHistory 检查访问者是否访问过某站点
Aug 02 Javascript
JS获取各种浏览器窗口大小的方法
Jan 14 Javascript
javascript读取Xml文件做一个二级联动菜单示例
Mar 17 Javascript
Javascript字符串对象的常用方法简明版
Jun 26 Javascript
Node.js 去掉种子(torrent)文件里的邪恶信息
Mar 27 Javascript
[Bootstrap-插件使用]Jcrop+fileinput组合实现头像上传功能实例代码
Dec 20 Javascript
使用DeviceOne实现微信小程序功能
Dec 29 Javascript
vue中v-model动态生成的实例详解
Oct 27 Javascript
原生JavaScript实现Ajax异步请求
Nov 19 Javascript
详解jQuery-each()方法
Mar 13 jQuery
使用Vue.js 和Chart.js制作绚丽多彩的图表
Jun 15 Javascript
vue实现点击追加选中样式效果
Nov 01 Javascript
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运行速度的一些小技巧分享
2012/07/03 PHP
PHP+MySQL修改记录的方法
2015/01/21 PHP
phpcms的分类名称和类别名称的调用
2017/01/05 PHP
phpstudy后门rce批量利用脚本的实现
2019/12/12 PHP
node.js中的http.request方法使用说明
2014/12/14 Javascript
JavaScript获取伪元素(Pseudo-Element)属性的方法技巧
2015/03/13 Javascript
javascript闭包的理解
2015/04/01 Javascript
Underscore源码分析
2015/12/30 Javascript
在Docker快速部署Node.js应用的详细步骤
2016/09/02 Javascript
jQuery如何解决IE输入框不能输入的问题
2016/10/08 Javascript
js利用appendChild对标签进行排序的实现方法
2016/10/16 Javascript
AngularJS中的缓存使用
2017/01/11 Javascript
vscode配置vue下的es6规范自动格式化详解
2019/03/20 Javascript
如何基于vue-cli3.0构建功能完善的移动端架子
2019/04/24 Javascript
vue增加强缓存和版本号的实现方法
2019/05/01 Javascript
Vue模板语法中数据绑定的实例代码
2019/05/17 Javascript
Express结合Webpack的全栈自动刷新
2019/05/23 Javascript
BootStrap表单验证中的非Submit类型按钮点击时触发验证的坑
2019/09/05 Javascript
JavaScript RegExp 对象用法详解
2019/09/24 Javascript
[01:02]2014 DOTA2国际邀请赛中国区预选赛 现场抢先看
2014/05/22 DOTA
[30:55]完美世界DOTA2联赛PWL S2 Magma vs LBZS 第二场 11.18
2020/11/18 DOTA
Python 遍历子文件和所有子文件夹的代码实例
2016/12/21 Python
Python数据结构与算法之字典树实现方法示例
2017/12/13 Python
浅谈Scrapy框架普通反爬虫机制的应对策略
2017/12/28 Python
Python将文本去空格并保存到txt文件中的实例
2018/07/24 Python
Python实现某论坛自动签到功能
2019/08/20 Python
基于ccs3的timeline时间线实现方法
2020/04/30 HTML / CSS
canvas学习总结三之绘制路径-线段
2019/01/31 HTML / CSS
如何利用cmp命令比较文件
2013/09/23 面试题
自荐信模版
2013/10/24 职场文书
数据员岗位职责
2013/11/19 职场文书
企业厂务公开实施方案
2014/03/26 职场文书
2014年国庆节活动总结
2014/08/26 职场文书
个人原因辞职信模板
2015/05/13 职场文书
博士论文答辩开场白
2015/06/01 职场文书
东京审判观后感
2015/06/01 职场文书