全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

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>

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!


# js弹性运动  # 弹性运动  # js导航条特效  # JavaScript拖拽、碰撞、重力及弹性运动实例分析  # 原生JS+CSS实现炫酷重力模拟弹跳系统的登录页面  # JavaScript模拟重力状态下抛物运动的方法  # Javascript实现重力弹跳拖拽运动效果示例  # 纯js模拟div层弹性运动的方法  # JS实现小球的弹性碰撞效果  # JS弹性运动实现方法分析  # js弹性势能动画之抛物线运动实例详解  # JavaScript实现重力下落与弹性效果的方法分析  # 首页  # 敲了  # 晚上  # 不出来  # height  # px  # padding  # margin  # width  # color  # orange  # left  # float  # line  # position  # auto  # relative  # list  # li  # Document 


相关文章: 网站制作软件有哪些,制图软件有哪些?  电脑免费海报制作网站推荐,招聘海报哪个网站多?  如何通过老薛主机一键快速建站?  山东网站制作公司有哪些,山东大源集团官网?  北京营销型网站制作公司,可以用python做一个营销推广网站吗?  如何在Windows服务器上快速搭建网站?  大型企业网站制作流程,做网站需要注册公司吗?  香港服务器网站生成指南:免费资源整合与高速稳定配置方案  南阳网站制作公司推荐,小学电子版试卷去哪里找资源好?  制作销售网站教学视频,销售网站有哪些?  标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?  如何在七牛云存储上搭建网站并设置自定义域名?  历史网站制作软件,华为如何找回被删除的网站?  如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?  建站主机是什么?如何选择适合的建站主机?  制作假网页,招聘网的薪资待遇,会有靠谱的吗?一面试又各种折扣?  北京的网站制作公司有哪些,哪个视频网站最好?  西安制作网站公司有哪些,西安货运司机用的最多的app或者网站是什么?  零基础网站服务器架设实战:轻量应用与域名解析配置指南  长沙做网站要多少钱,长沙国安网络怎么样?  如何确保西部建站助手FTP传输的安全性?  阿里云网站制作公司,阿里云快速搭建网站好用吗?  定制建站模板如何实现SEO优化与智能系统配置?18字教程  开封网站制作公司,网络用语开封是什么意思?  如何在IIS中新建站点并配置端口与物理路径?  如何零基础在云服务器搭建WordPress站点?  建站之星免费版是否永久可用?  网站制作和推广的区别,想自己建立一个网站做推广,有什么快捷方法马上做好一个网站?  网站制作免费,什么网站能看正片电影?  红河网站制作公司,红河事业单位身份证如何上传?  ,网站推广常用方法?  魔方云NAT建站如何实现端口转发?  如何正确选择百度移动适配建站域名?  如何在云主机快速搭建网站站点?  定制建站流程解析:需求评估与SEO优化功能开发指南  制作农业网站的软件,比较好的农业网站推荐一下?  高端云建站费用究竟需要多少预算?  免费视频制作网站,更新又快又好的免费电影网站?  如何制作一个表白网站视频,关于勇敢表白的小标题?  c++如何打印函数堆栈信息_c++ backtrace函数与符号名解析【方法】  微信小程序 五星评分(包括半颗星评分)实例代码  如何在阿里云高效完成企业建站全流程?  制作国外网站的软件,国外有哪些比较优质的网站推荐?  如何在西部数码注册域名并快速搭建网站?  制作网站建设的公司有哪些,网站建设比较好的公司都有哪些?  内网网站制作软件,内网的网站如何发布到外网?  如何用花生壳三步快速搭建专属网站?  学校免费自助建站系统:智能生成+拖拽设计+多端适配  如何在橙子建站上传落地页?操作指南详解  建站之星导航菜单设置与功能模块配置全攻略 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。