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在线选座位插件seat-charts特效代码分享
Aug 27 Javascript
浅谈jQuery中ajaxPrefilter的应用
Aug 01 Javascript
jquery实现输入框实时输入触发事件代码
Dec 21 Javascript
angularjs利用directive实现移动端自定义软键盘的示例
Sep 20 Javascript
基于JavaScript实现简单的音频播放功能
Jan 07 Javascript
vue better-scroll插件使用详解
Jan 25 Javascript
mint-ui 时间插件使用及获取选择值的方法
Feb 09 Javascript
javascript显示动态时间的方法汇总
Jul 06 Javascript
JS 实现微信扫一扫功能
Sep 14 Javascript
对angularJs中$sce服务安全显示html文本的实例
Sep 30 Javascript
vue中引入第三方字体文件的方法示例
Dec 17 Javascript
javascript实现移动端轮播图
Dec 09 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
欧美媒体选出10年前最流行的17部动画
2017/01/18 日漫
基于php伪静态的实现详细介绍
2013/04/28 PHP
PHP和javascript常用正则表达式及用法实例
2014/07/01 PHP
PHP判断网络文件是否存在的方法
2015/03/12 PHP
支持汉转拼和拼音分词的PHP中文工具类ChineseUtil
2018/02/23 PHP
PHP延迟静态绑定的深入讲解
2018/04/02 PHP
jquery 多行文本框(textarea)高度变化
2013/07/03 Javascript
jQuery中验证表单提交方式及序列化表单内容的实现
2014/01/06 Javascript
js简单的点击返回顶部效果实现方法
2015/04/10 Javascript
jquery使用each方法遍历json格式数据实例
2015/05/18 Javascript
jQuery实现文件上传进度条特效
2015/08/12 Javascript
angularJs使用$watch和$filter过滤器制作搜索筛选实例
2017/06/01 Javascript
Vue封装一个简单轻量的上传文件组件的示例
2018/03/21 Javascript
简谈创建React Component的几种方式
2019/06/15 Javascript
vue filter 完美时间日期格式的代码
2019/08/14 Javascript
js瀑布流布局的实现
2020/06/28 Javascript
[03:59]DOTA2英雄梦之声_第07期_水晶室女
2014/06/23 DOTA
haskell实现多线程服务器实例代码
2013/11/26 Python
Python实现的一个自动售饮料程序代码分享
2014/08/25 Python
Python实现竖排打印传单手机号码易撕条
2015/03/16 Python
使用相同的Apache实例来运行Django和Media文件
2015/07/22 Python
利用Pandas读取文件路径或文件名称包含中文的csv文件方法
2018/07/04 Python
关于Pycharm无法debug问题的总结
2019/01/19 Python
python实现扫描局域网指定网段ip的方法
2019/04/16 Python
python requests使用socks5的例子
2019/07/25 Python
python递归下载文件夹下所有文件
2019/08/31 Python
在线购买澳大利亚设计师手拿包和奢华晚装手袋:Olga Berg
2019/03/20 全球购物
农业大学毕业生的个人自我评价
2013/10/11 职场文书
木工主管岗位职责
2013/12/08 职场文书
学生实习介绍信
2014/01/15 职场文书
高中军训感言800字
2014/03/05 职场文书
《厄运打不垮的信念》教学反思
2014/04/13 职场文书
十佳文明家庭事迹
2014/05/25 职场文书
观看《周恩来的四个昼夜》思想汇报
2014/09/12 职场文书
新员工试用期工作总结2015
2015/05/28 职场文书
Nginx内网单机反向代理的实现
2021/11/07 Servers