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.fn和jQuery.prototype区别介绍
Oct 05 Javascript
jQuery中bind,live,delegate与one方法的用法及区别解析
Dec 30 Javascript
JS判断页面是否出现滚动条的方法
Jul 17 Javascript
详解JavaScript对象和数组
Dec 03 Javascript
AngularJS基础 ng-csp 指令详解
Aug 01 Javascript
jQuery 选择器(61种)整理总结
Sep 26 Javascript
Node+Express+MongoDB实现登录注册功能实例
Apr 23 Javascript
AngualrJs清除定时器遇到的坑
Oct 13 Javascript
JavaScript 异步调用
Oct 25 Javascript
jQuery简单实现根据日期计算星期几的方法
Jan 09 jQuery
vue仿淘宝滑动验证码功能(样式模仿)
Dec 10 Javascript
js 压缩图片的示例(只缩小体积,不更改图片尺寸)
Oct 21 Javascript
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程序级守护进程的实现与优化的使用概述
2013/05/02 PHP
PHP防止跨域提交表单
2013/11/01 PHP
codeigniter显示所有脚本执行时间的方法
2015/03/21 PHP
PHP实现登陆并抓取微信列表中最新一组微信消息的方法
2017/07/10 PHP
PHP数组与字符串互相转换实例
2020/05/05 PHP
nodejs入门详解(多篇文章结合)
2012/03/07 NodeJs
Jquery之Bind方法参数传递与接收的三种方法
2014/06/24 Javascript
javascript定义类和类的实现实例详解
2015/12/01 Javascript
jquery实现列表上下移动功能
2016/02/25 Javascript
jQuery Mobile页面返回不需要重新get
2016/04/26 Javascript
nodejs开发微信小程序实现密码加密
2017/07/11 NodeJs
nginx+vue.js实现前后端分离的示例代码
2018/02/12 Javascript
vue中父子组件注意事项,传值及slot应用技巧
2018/05/09 Javascript
JavaScript实现邮箱后缀提示功能的示例代码
2018/12/13 Javascript
Angular2实现的秒表及改良版示例
2019/05/10 Javascript
JS实现页面跳转与刷新的方法汇总
2019/08/30 Javascript
vue离开当前页面触发的函数代码
2020/09/01 Javascript
javascript canvas封装动态时钟
2020/09/30 Javascript
快速解决vue2+vue-cli3项目ie兼容的问题
2020/11/17 Vue.js
[07:57]2018DOTA2国际邀请赛寻真——PSG.LGD凤凰浴火
2018/08/12 DOTA
Python多线程编程简单介绍
2015/04/13 Python
python正则表达式匹配不包含某几个字符的字符串方法
2019/07/23 Python
Python Web静态服务器非堵塞模式实现方法示例
2019/11/21 Python
解决springboot yml配置 logging.level 报错问题
2020/02/21 Python
pandas分批读取大数据集教程
2020/06/06 Python
Python中读取文件名中的数字的实例详解
2020/12/25 Python
StubHub新加坡:购买和出售全球活动门票
2017/03/10 全球购物
最新远光软件笔试题面试题内容
2013/11/08 面试题
使用C#编写创建一个线程的代码
2013/01/22 面试题
校园报刊亭的创业计划书
2014/01/02 职场文书
干部选拔任用方案
2014/05/26 职场文书
授权委托书格式范文
2014/08/02 职场文书
企业授权委托书范本
2014/09/22 职场文书
2014年党员整改措施
2014/10/24 职场文书
职工宿舍管理制度
2015/08/05 职场文书
Jupyter notebook 更改文件打开的默认路径操作
2021/05/21 Python