js实现带简单弹性运动的导航条


Posted in Javascript onFebruary 22, 2017

晚上跟着视频敲了下 弹性菜单的代码,先记下来

效果如下:

js实现带简单弹性运动的导航条

代码如下:

<!doctype html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>Document</title>
 <style>
 *{
  margin:0;
  padding:0;
 }
 .ul1{
  width:450px;
  height:30px;
  margin:20px auto;
  position:relative;
 }
 li{
  list-style:none;
  line-height:30px;
  height:30px;
  width:100px;
  color:orange;
  text-align:center;
  float:left;
  margin-right:5px;
  border:1px soli #000;
  background-color:red;
 }
 .mark{
  position:absolute;
  left:0;
  top:0;
  overflow:hidden;
 }
 .mark ul{
  width:450px;
  position:absolute;
  left:0;
  top:0;
 }
 .mark ul li{
  color:#fff;
  background-color:deepskyblue;
 }
 </style>
</head>
<body>
<ul class="ul1">
 <li class="mark">
 <ul>
  <li>首页</li>
  <li>论坛</li>
  <li>视频</li>
  <li>课程</li>
 </ul>
 </li>
 <li class="box">首页</li>
 <li class="box">论坛</li>
 <li class="box">视频</li>
 <li class="box">课程</li>
</ul>
</body>
<script>
 window.onload = function(){
 var oMark = document.querySelector('.mark');
 var oBox = document.querySelectorAll('.box');
 var childUl = oMark.querySelector('ul');
 var timer = null;
 var timer2 = null;//延迟定时器,100毫秒人的眼睛是察觉不出来的
 var iSpeed = 0;
 for (var i=0;i<oBox.length;i++){
  oBox[i].onmouseover = function(){
  clearTimeout(timer2);
  startMove(this.offsetLeft);
  };
  oBox[i].onmouseout = function(){
  timer2 = setTimeout(function(){
   startMove(0);
  },100);

  };
 }
 oMark.onmouseover = function(){
  clearTimeout(timer2);
 };
 oMark.onmouseout= function(){
  timer2 = setTimeout(function(){
  startMove(0);
  },100);
 };
 function startMove(iTarget){
  clearInterval(timer);
  timer = setInterval(function(){
  iSpeed += (iTarget -oMark.offsetLeft)/5;
  iSpeed *= 0.75;
  if(Math.abs(iSpeed)<=1 && Math.abs(iTarget -oMark.offsetLeft)<=1){
   clearInterval(timer);
   oMark.style.left = iTarget + 'px';
   childUl.style.left = -iTarget + 'px';
   iSpeed = 0;
  }else {
   oMark.style.left = oMark.offsetLeft + iSpeed +'px';
   childUl.style.left = -oMark.offsetLeft +'px';
  }
  },30);
 };
 };
</script>
</html>

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
在textarea中屏蔽js的某个function的javascript代码
Apr 20 Javascript
ie下动态加态js文件的方法
Sep 13 Javascript
初识SmartJS - AOP三剑客
Jun 08 Javascript
JavaScript实现列表分页功能特效
May 15 Javascript
Angular中$compile源码分析
Jan 28 Javascript
vue v-model表单控件绑定详解
May 17 Javascript
详解webpack自动生成html页面
Jun 29 Javascript
详细分析单线程JS执行问题
Nov 22 Javascript
教你如何编写Vue.js的单元测试的方法
Oct 17 Javascript
使用mixins实现elementUI表单全局验证的解决方法
Apr 02 Javascript
Vue computed 计算属性代码实例
Apr 22 Javascript
Vue 列表页带参数进详情页的操作(router-link)
Nov 13 Javascript
bootstrap fileinput 插件使用项目总结(经验)
Feb 22 #Javascript
javascript 网页进度条简单实例
Feb 22 #Javascript
详解闭包解决jQuery中AJAX的外部变量问题
Feb 22 #Javascript
js实现PC端根据IP定位当前城市地理位置
Feb 22 #Javascript
纯JS实现轮播图
Feb 22 #Javascript
javascript 操作cookies详解及实例
Feb 22 #Javascript
jquery实现手机端单店铺购物车结算删除功能
Feb 22 #Javascript
You might like
php 根据自增id创建唯一编号类
2017/04/06 PHP
PHP实现的超长文本分页显示功能示例
2018/06/04 PHP
抽出www.templatemonster.com的鼠标悬停加载大图模板的代码
2007/07/11 Javascript
在网页里看flash的trace数据的js类
2009/01/10 Javascript
asp.net HttpHandler实现图片防盗链
2009/11/09 Javascript
为什么要在引入的css或者js文件后面加参数的详细讲解
2013/05/03 Javascript
jquery批量设置属性readonly和disabled的方法
2014/01/24 Javascript
jquery实现保存已选用户
2014/07/21 Javascript
jQuery实现点击图片翻页展示效果的方法
2015/02/16 Javascript
JS+DIV+CSS排版布局实现美观的选项卡效果
2015/10/10 Javascript
浅谈javascript中replace()方法
2015/11/10 Javascript
深入理解JavaScript内置函数
2016/06/03 Javascript
基于JS实现发送短信验证码后的倒计时功能(无视页面刷新,页面关闭不进行倒计时功能)
2016/09/02 Javascript
Bootstrap.css与layDate日期选择样式起冲突的解决办法
2017/04/07 Javascript
利用vueJs实现图片轮播实例代码
2017/06/03 Javascript
angular-ngSanitize模块-$sanitize服务详解
2017/06/13 Javascript
原生JS+Canvas实现五子棋游戏实例
2017/06/19 Javascript
原生JS上传大文件显示进度条 php上传文件代码
2020/03/27 Javascript
React props和state属性的具体使用方法
2018/04/12 Javascript
vue.js与element-ui实现菜单树形结构的解决方法
2018/04/21 Javascript
vue.js中实现登录控制的方法示例
2018/04/23 Javascript
vue-cli3.0 脚手架搭建项目的过程详解
2018/10/19 Javascript
vue实现微信二次分享以及自定义分享的示例
2019/03/20 Javascript
vue轻量级框架无法获取到vue对象解决方法
2019/05/12 Javascript
JS中FormData类实现文件上传
2020/03/27 Javascript
Python正则抓取新闻标题和链接的方法示例
2017/04/24 Python
Python根据已知邻接矩阵绘制无向图操作示例
2018/06/23 Python
python如何基于redis实现ip代理池
2020/01/17 Python
Python ORM框架Peewee用法详解
2020/04/29 Python
Python依赖包迁移到断网环境操作
2020/07/13 Python
在线吉他课程,学习如何弹吉他:Fender Play
2019/02/28 全球购物
英国最好的温室之家:Greenhouses Direct
2019/07/13 全球购物
当当网软件测试笔试题
2015/11/24 面试题
人力资源部经理岗位职责规定
2014/02/23 职场文书
教师敬业奉献模范事迹材料
2014/05/18 职场文书
党员干部四风问题整改措施思想汇报
2014/10/12 职场文书