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 发个判断字符串是否为符合标准的函数
Apr 27 Javascript
浅析offsetLeft,Left,clientLeft之间的区别
Nov 30 Javascript
jQuery控制TR显示隐藏的三种常用方法
Aug 21 Javascript
jQuery实现简单的日期输入格式化控件
Mar 12 Javascript
详解JavaScript中常用的函数类型
Nov 18 Javascript
jQuery实现页面下拉100像素出现悬浮窗口的方法
Sep 05 Javascript
浅谈js中用$(#ID)来作为选择器的问题(id重复的时候)
Feb 14 Javascript
JS传播事件、取消事件默认行为、阻止事件传播详解
Aug 14 Javascript
浅谈react性能优化的方法
Sep 05 Javascript
Vue.js轮播图走马灯代码实例(全)
May 08 Javascript
vue下使用nginx刷新页面404的问题解决
Aug 02 Javascript
vue 使用高德地图vue-amap组件过程解析
Sep 07 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 XML备份Mysql数据库
2009/05/27 PHP
PHP四舍五入精确小数位及取整
2014/01/14 PHP
php多种形式发送邮件(mail qmail邮件系统 phpmailer类)
2014/01/22 PHP
php中10个不同等级压缩优化图片操作示例
2016/11/14 PHP
PHP查询分页的实现代码
2017/06/09 PHP
Laravel接收前端ajax传来的数据的实例代码
2017/07/20 PHP
用js实现层随着内容大小动态渐变改变 推荐
2009/12/19 Javascript
基于jquery实现控制经纬度显示地图与卫星
2013/05/20 Javascript
JavaScript获取多个数组的交集简单实例
2013/11/11 Javascript
ext combobox动态加载数据库数据(附前后台)
2014/06/17 Javascript
Javascript核心读书有感之语言核心
2015/02/01 Javascript
jquery表单验证插件(jquery.validate.js)的3种使用方式
2015/03/28 Javascript
JavaScript中var关键字的使用详解
2015/08/14 Javascript
Bootstrap三种表单布局的使用方法
2016/06/21 Javascript
ajax实现加载页面、删除、查看详细信息 bootstrap美化页面!
2017/03/14 Javascript
vue-router的使用方法及含参数的配置方法
2018/11/13 Javascript
Python 用户登录验证的小例子
2013/03/06 Python
vc6编写python扩展的方法分享
2014/01/17 Python
使用PDB简单调试Python程序简明指南
2015/04/25 Python
开始着手第一个Django项目
2015/07/15 Python
Python 迭代器与生成器实例详解
2017/05/18 Python
python线程池threadpool使用篇
2018/04/27 Python
Python3操作Excel文件(读写)的简单实例
2019/09/02 Python
Python 输出详细的异常信息(traceback)方式
2020/04/08 Python
jupyter 导入csv文件方式
2020/04/21 Python
python爬虫要用到的库总结
2020/07/28 Python
详解用selenium来下载小姐姐图片并保存
2021/01/26 Python
常用的四种CSS透明属性介绍
2014/04/12 HTML / CSS
html5适合移动应用开发的12大特性
2014/03/19 HTML / CSS
html5录音功能实战示例
2019/03/25 HTML / CSS
娇韵诗Clarins意大利官方网站:法国天然护肤品牌
2020/03/11 全球购物
甜点店创业计划书
2014/01/27 职场文书
财务总监管理职责范文
2014/03/09 职场文书
2014年电厂个人工作总结
2014/11/27 职场文书
OpenCV-Python实现轮廓拟合
2021/06/08 Python
Win10 heic文件怎么打开 ? Win10 heic文件打开教程
2022/04/06 数码科技