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 相关文章推荐
jQuery实现炫酷的鼠标轨迹特效
Feb 01 Javascript
JS实现带有3D立体感的银灰色竖排折叠菜单代码
Oct 20 Javascript
ajax的分页查询示例(不刷新页面)
Jan 11 Javascript
BootStrap Table 后台数据绑定、特殊列处理、排序功能
May 27 Javascript
详解Angular2表单-模板驱动的表单(Template-Driven Forms)
Aug 04 Javascript
vue中倒计时组件的实例代码
Jul 06 Javascript
不得不知的ES6小技巧
Jul 28 Javascript
详解element-ui中el-select的默认选择项问题
Aug 02 Javascript
微信小程序如何实现在线客服功能
Oct 16 Javascript
vue离开当前页面触发的函数代码
Sep 01 Javascript
vue 动态组件(component :is) 和 dom元素限制(is)用法说明
Sep 04 Javascript
element tree树形组件回显数据问题解决
Aug 14 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/06/25 PHP
php 魔术常量详解及实例代码
2016/12/04 PHP
PHP中危险的file_put_contents函数详解
2017/11/04 PHP
js 事件小结 表格区别
2007/08/13 Javascript
JQuery Tips(2) 关于$()包装集你不知道的
2009/12/14 Javascript
ajax请求get与post的区别总结
2013/11/04 Javascript
JavaScript操作Cookie详解
2015/02/28 Javascript
jQuery幻灯片带缩略图轮播效果代码分享
2015/08/17 Javascript
JS控制FileUpload的上传文件类型实例代码
2016/10/07 Javascript
javascript实现下雨效果
2017/03/27 Javascript
详解angularJS动态生成的页面中ng-click无效解决办法
2017/06/19 Javascript
mui开发中获取单选按钮、复选框的值(实例讲解)
2017/07/24 Javascript
Vue 样式绑定的实现方法
2019/01/15 Javascript
JS集合set类的实现与使用方法示例
2019/02/01 Javascript
JS对象和字符串之间互换操作实例分析
2019/02/02 Javascript
基于mpvue搭建微信小程序项目框架的教程详解
2019/04/10 Javascript
详解es6新增数组方法简便了哪些操作
2019/05/09 Javascript
python异步任务队列示例
2014/04/01 Python
web.py获取上传文件名的正确方法
2014/08/26 Python
python中随机函数random用法实例
2015/04/30 Python
使用pyecharts在jupyter notebook上绘图
2020/04/23 Python
解决python matplotlib imshow无法显示的问题
2018/05/24 Python
使用python语言,比较两个字符串是否相同的实例
2018/06/29 Python
VSCode Python开发环境配置的详细步骤
2019/02/22 Python
django多对多表的创建,级联删除及手动创建第三张表
2019/07/25 Python
python 函数的缺省参数使用注意事项分析
2019/09/17 Python
将python包发布到PyPI和制作whl文件方式
2019/12/25 Python
沙特阿拉伯家用电器和电子产品购物网站:Sheta and Saif
2020/04/03 全球购物
如何用SQL语句进行模糊查找
2015/09/25 面试题
应聘美工求职信
2013/11/07 职场文书
主治医师岗位职责
2013/12/10 职场文书
企业申诉管理制度
2014/01/30 职场文书
土地转让协议书范本
2014/04/15 职场文书
经典演讲稿开场白
2014/08/25 职场文书
践行三严三实心得体会
2014/10/13 职场文书
2015年医务科工作总结范文
2015/05/26 职场文书