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 相关文章推荐
js Event对象的5种坐标
Sep 12 Javascript
JS匀速运动演示示例代码
Nov 26 Javascript
Node.js事件驱动
Jun 18 Javascript
AngularJS 依赖注入详解和简单实例
Jul 28 Javascript
把多个JavaScript函数绑定到onload事件处理函数上的方法
Sep 04 Javascript
原生js实现新闻列表展开/收起全文功能
Jan 20 Javascript
JavaScript设计模式之工厂模式简单实例教程
Jul 03 Javascript
微信小程序 swiper 组件遇到的问题及解决方法
May 26 Javascript
详解webpack打包vue项目之后生成的dist文件该怎么启动运行
Sep 06 Javascript
利用JS代码自动删除稿件的普通弹幕功能
Sep 20 Javascript
jQuery单页面文字搜索插件jquery.fullsearch.js的使用方法
Feb 04 jQuery
vue+elementUI(el-upload)图片压缩,默认同比例压缩操作
Aug 10 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无限遍历目录示例
2014/02/21 PHP
PHP文字转图片功能原理与实现方法分析
2017/08/31 PHP
ThinkPHP 框架实现的读取excel导入数据库操作示例
2020/04/14 PHP
In Javascript Class, how to call the prototype method.(three method)
2007/01/09 Javascript
SWFObject 2.1以上版本语法介绍
2010/07/10 Javascript
jQuery EasyUI API 中文文档 - PropertyGrid属性表格
2011/11/18 Javascript
IE及IE6浏览器中判断JS文件加载成功失败的方法
2015/02/18 Javascript
JavaScript中ES6字符串扩展方法
2016/08/26 Javascript
easyUI实现(alert)提示框自动关闭的实例代码
2016/11/07 Javascript
node.js报错:Cannot find module 'ejs'的解决办法
2016/12/14 Javascript
JavaScript严格模式详解
2017/01/16 Javascript
jQuery插件HighCharts绘制2D柱状图、折线图和饼图的组合图效果示例【附demo源码下载】
2017/03/09 Javascript
js登录滑动验证的实现(不滑动无法登陆)
2018/01/03 Javascript
vue 子组件向父组件传值方法
2018/02/26 Javascript
vue中子组件的methods中获取到props中的值方法
2018/08/27 Javascript
jQuery 获取除某指定对象外的其他对象 ( :not() 与.not())
2018/10/10 jQuery
ES6顶层对象、global对象实例分析
2019/06/14 Javascript
[01:06:26]全国守擂赛第二周 Team Coach vs DeMonsTer
2020/04/28 DOTA
浅析python3中的os.path.dirname(__file__)的使用
2018/08/30 Python
Django2.1集成xadmin管理后台所遇到的错误集锦(填坑)
2018/12/20 Python
python 在某.py文件中调用其他.py内的函数的方法
2019/06/25 Python
详解Django模版中加载静态文件配置方法
2019/07/21 Python
Python pandas用法最全整理
2019/08/04 Python
Python一键安装全部依赖包的方法
2019/08/12 Python
python中利用numpy.array()实现俩个数值列表的对应相加方法
2019/08/26 Python
Python实现粒子群算法的示例
2021/02/14 Python
"引用"与指针的区别是什么
2016/09/07 面试题
在C#中如何实现多态
2014/07/02 面试题
EJB与JAVA BEAN的区别
2016/08/29 面试题
检讨书格式
2015/01/23 职场文书
学校捐书倡议书
2015/04/27 职场文书
学校德育工作总结2015
2015/05/11 职场文书
大学生党课心得体会
2016/01/07 职场文书
golang json数组拼接的实例
2021/04/28 Golang
室外天线与收音机天线杆接合方法
2022/04/05 无线电
Python保存并浏览用户的历史记录
2022/04/29 Python