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中的$(document).ready()使用小结
Feb 14 Javascript
jQuery对象的length属性用法实例
Dec 27 Javascript
js控制元素显示在屏幕固定位置及监听屏幕高度变化的方法
Aug 11 Javascript
js控制多图左右滚动切换效果代码分享
Aug 26 Javascript
jQuery往返城市和日期查询实例讲解
Oct 09 Javascript
基于jQuery实现收缩展开功能
Mar 18 Javascript
如何利用Promises编写更优雅的JavaScript代码
May 17 Javascript
Vue 去除路径中的#号
Apr 19 Javascript
js调用设备摄像头的方法
Jul 19 Javascript
jQuery 实现倒计时天,时,分,秒功能
Jul 31 jQuery
vue 动态绑定背景图片的方法
Aug 10 Javascript
浅谈Vue为什么不能检测数组变动
Oct 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
咖啡冲泡指南 咖啡有哪些制作方式 单品咖啡 意式咖啡
2021/03/06 冲泡冲煮
2014年10个最佳的PHP图像操作库
2014/07/14 PHP
PHP开发中解决并发问题的几种实现方法分析
2017/11/13 PHP
php和vue配合使用技巧和方法
2019/05/09 PHP
php菜单/评论数据递归分级算法的实现方法
2019/08/01 PHP
List Information About the Binary Files Used by an Application
2007/06/18 Javascript
IE和Firefox下javascript的兼容写法小结
2008/12/10 Javascript
Jquery 1.42 checkbox 全选和反选代码
2010/03/27 Javascript
js/jQuery对象互转(快速操作dom元素)
2013/02/04 Javascript
Javascript判断对象是否相等实现代码
2013/03/18 Javascript
网站接入QQ登录的两种方法
2014/07/22 Javascript
JQuery中使用Ajax赋值给全局变量失败异常的解决方法
2014/08/18 Javascript
JS中的THIS和WINDOW.EVENT.SRCELEMENT详解
2015/05/25 Javascript
JavaScript中引用vs复制示例详析
2018/12/06 Javascript
vue 实现 rem 布局或vw 布局的方法
2019/11/13 Javascript
[07:25]DOTA2-DPC中国联赛2月5日Recap集锦
2021/03/11 DOTA
Python ORM框架SQLAlchemy学习笔记之关系映射实例
2014/06/10 Python
python使用锁访问共享变量实例解析
2018/02/08 Python
详解python和matlab的优势与区别
2019/06/28 Python
用Python实现将一张图片分成9宫格的示例
2019/07/05 Python
使用虚拟环境打包python为exe 文件的方法
2019/08/29 Python
如何让IE9以下版本(ie6/7/8)认识html5元素
2013/04/01 HTML / CSS
DHC美国官网:日本通信销售第一的化妆品品牌
2017/11/12 全球购物
北卡罗来纳州豪华家具和家居装饰店:Carolina Rustica
2018/10/30 全球购物
7 For All Mankind官网:美国加州洛杉矶的高级牛仔服装品牌
2018/12/20 全球购物
新加坡第一的杂货零售商:NTUC FairPrice
2020/12/05 全球购物
给老师的一封建议书
2014/03/13 职场文书
农村优秀教师事迹材料
2014/08/27 职场文书
中学生的1000字检讨书
2014/10/11 职场文书
2014年语文教研组工作总结
2014/12/06 职场文书
幼儿园小班教师随笔
2015/08/14 职场文书
2016个人廉洁自律承诺书
2016/03/25 职场文书
农村房屋租赁合同(范本)
2019/07/23 职场文书
四年级作文之植物
2019/09/20 职场文书
如何打开Win11系统注册表编辑器?Win11注册表编辑器打开修复方法
2022/04/05 数码科技
Java 多线程协作作业之信号同步
2022/05/11 Java/Android