JavaScript实现精美个性导航栏筋斗云效果


Posted in Javascript onOctober 29, 2017

实现效果:

实现效果如下图所示

JavaScript实现精美个性导航栏筋斗云效果

实现原理:

什么是筋斗云效果:

•这个效果很简单,就是鼠标移到其他导航目录时会有背景图片跟着鼠标滑动到当前的目录。

实现思路:

•鼠标经过的时候,利用offsetLeft获得当前盒子距离左侧的距离,把这个值赋给缓动动画的end值。
•当点击的时候记住当前的offsetLeft值,当鼠标经过的时候把之前点击的offsetLeft给现在经过时候的值。

实现代码:

下面是实现代码以及详细注释,核心设置一个position为absolute的span标签,通过绑定鼠标事件,用封装好的animate动画实现span的“筋斗云”效果。

<!DOCTYPE html>
<html>
<head>
  <title>导航栏筋斗云效果</title>
  <meta charset="utf-8">
  <style type="text/css">
    *{
      padding: 0;
      margin: 0;
    }
    body{
      background-color: rgba(0, 0, 0, 0.6);
    }
    .box{
      width: 415px;
      height: 42px;
      margin: 200px auto;
      background-color: #fff;
      position: relative;
    }
    ul{
      list-style: none;
      position: relative;
    }
    li{
      float: left;
      width: 83px;
      height: 42px;
      text-align: center;
      font: 500 15px/42px "微软雅黑";
      cursor: pointer;
    }
    span{
      position: absolute;
      left: 0;
      top: 0;
      width: 83px;
      height: 42px;
      background-image: linear-gradient(to right,#03c03c 50% ,#51ee5d 100%);
    }
  </style>
</head>
<body>
<div class="box">
  <span></span>
  <ul>
    <li>菜单栏1</li>
    <li>菜单栏2</li>
    <li>菜单栏3</li>
    <li>菜单栏4</li>
    <li>菜单栏5</li>
  </ul>
</div>
<script type="text/javascript">
  window.onload = function(){
    // 鼠标放在哪个li上面,span对应一道到哪里,移开后回到原位置
    var liArr = document.getElementsByTagName("li");
    var liWidth = liArr[0].offsetWidth;
    var span = document.getElementsByTagName("span")[0];
    // 计数器
    var cnt = 0;
    // for循环绑定事件
    for(var i=0; i<liArr.length; i++){
      // 自定义属性,然后绑定index属性为索引值
      liArr[i].index = i;
      // 鼠标进入事件
      liArr[i].onmouseover = function(){
        // 然span运动到该li的索引值位置
        animate(span, this.index*liWidth);
      }
      // 鼠标移开
      liArr[i].onmouseout = function(){
        // span运动到原位置
        animate(span, cnt*liWidth);
      }
      // 点击事件
      liArr[i].onclick = function(){
        // 计数器记录当前标签索引值
        cnt = this.index;
        animate(span, cnt*liWidth);
      }
    }
    // 缓动动画封装
    function animate(element, target){
      // 清除间歇调用
      clearInterval(element.timer);
      // 设置超时调用
      element.timer = setInterval(function(){
        // 设置步数
        var step = (target - element.offsetLeft)/10;
        // 调整步数
        step = step > 0 ? Math.ceil(step) : Math.floor(step);
        // 设置样式
        element.style.left = element.offsetLeft + step + "px";
        // console.log(1);
        if(Math.abs(target - element.offsetLeft) < Math.abs(step)){
          element.style.left = target + "px";
          clearInterval(element.timer);
        }
      }, 20);
    }
  }
</script>
</body>
</html>

总结

以上所述是小编给大家介绍的JavaScript实现精美个性导航栏筋斗云效果,希望对大家有所帮助!

Javascript 相关文章推荐
jQuery Study Notes学习笔记 (二)
Aug 04 Javascript
jquery 年会抽奖程序
Dec 22 Javascript
分享XmlHttpRequest调用Webservice的一点心得
Jul 20 Javascript
jQuery实现炫酷的鼠标轨迹特效
Feb 01 Javascript
JavaScript中的分号插入机制详细介绍
Feb 11 Javascript
详解WordPress开发中get_current_screen()函数的使用
Jan 11 Javascript
jQuery内存泄露解决办法
Dec 13 Javascript
jQuery实现遍历复选框的方法示例
Mar 06 Javascript
ES6中数组array新增方法实例总结
Nov 07 Javascript
详解plotly.js 绘图库入门使用教程
Feb 23 Javascript
JavaScript选择器函数querySelector和querySelectorAll
Nov 27 Javascript
Element-ui Layout布局(Row和Col组件)的实现
Dec 06 Vue.js
vue中的scope使用详解
Oct 29 #Javascript
Vue.js划分组件的方法
Oct 29 #Javascript
vue.js  父向子组件传参的实例代码
Oct 29 #Javascript
vue.js todolist实现代码
Oct 29 #Javascript
javascript按钮禁用和启用的效果实例代码
Oct 29 #Javascript
jQuery实现切换隐藏与显示同时切换图标功能
Oct 29 #jQuery
bootstrap table sum总数量统计实现方法
Oct 29 #Javascript
You might like
PHP添加图片水印、压缩、剪切的封装类
2015/08/17 PHP
PHP中函数gzuncompress无法使用的解决方法
2017/03/02 PHP
PHP中的浅复制与深复制的实例详解
2017/10/26 PHP
layui数据表格自定义每页条数limit设置
2019/10/26 PHP
解密效果
2006/06/23 Javascript
ExtJS 工具栏 分页事件参数
2010/03/05 Javascript
用js判断页面是否加载完成实现代码
2012/12/11 Javascript
自写的jQuery异步加载数据添加事件
2014/05/15 Javascript
JavaScript显示表单内元素数量的方法
2015/04/02 Javascript
Express的路由详解
2015/12/10 Javascript
BootStrap 附加导航组件
2016/07/22 Javascript
浅谈toLowerCase和toLocaleLowerCase的区别
2016/08/15 Javascript
详解javascript中对数据格式化的思考
2017/01/23 Javascript
js转换对象为xml
2017/02/17 Javascript
JQueryMiniUI按照时间进行查询的实现方法
2017/06/07 jQuery
react-native-fs实现文件下载、文本存储的示例代码
2017/09/22 Javascript
详解Angular中实现自定义组件的双向绑定的两种方法
2018/11/23 Javascript
js抽奖转盘实现方法分析
2020/05/16 Javascript
微信小程序实现分页加载效果
2020/11/19 Javascript
pycharm 使用心得(四)显示行号
2014/06/05 Python
python中requests模块的使用方法
2015/04/08 Python
Python通过Django实现用户注册和邮箱验证功能代码
2017/12/11 Python
python清除字符串中间空格的实例讲解
2018/05/11 Python
用Python实现数据的透视表的方法
2018/11/16 Python
python如何查看微信消息撤回
2018/11/27 Python
Python玩转Excel的读写改实例
2019/02/22 Python
使用Python操作FTP实现上传和下载的方法
2019/04/01 Python
Python中format()格式输出全解
2019/04/12 Python
Django中从mysql数据库中获取数据传到echarts方式
2020/04/07 Python
戴尔加拿大官网:Dell加拿大
2016/09/17 全球购物
小城镇建设汇报材料
2014/08/16 职场文书
党代会心得体会
2014/09/04 职场文书
财务经理岗位职责
2015/01/31 职场文书
施工员岗位职责范本
2015/04/11 职场文书
Python中相见恨晚的技巧
2021/04/13 Python
django上传文件的三种方式
2021/04/29 Python