js实现缓动动画


Posted in Javascript onNovember 25, 2020

本文实例为大家分享了js实现缓动动画的具体代码,供大家参考,具体内容如下

js实现缓动动画

利用定时器来控制元素的offsetLeft的值,offsetLeft = 开始位置 + (最终位置 - 开始位置)* 缓动系数

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>Title</title>

 <style>
 * {
  margin: 0;
  padding: 0;
  border: none;
  list-style: none;
 }

 body {
  background-color: pink;
 }

 #nav {
  width: 900px;
  height: 63px;
  background: url("images/doubleOne.png") no-repeat right center #fff;
  margin: 0 auto;
  margin-top: 50px;
  border-radius: 5px;
  position: relative;
 }

 #nav ul {
  line-height: 70px;
 }

 #nav ul li {
  float: left;
  height: 63px;
  width: 88px;
  text-align: center;
  cursor: pointer;
  position: relative;
 }

 #t_mail {
  width: 88px;
  height: 63px;
  background: url("images/tMall.png") no-repeat;
  position: absolute;
 }
 </style>
</head>
<body>
 <nav id="nav">
 <span id="t_mail"></span>
  <ul>
  <li>双11狂欢</li>
  <li>服装会场</li>
  <li>数码家电</li>
  <li>母婴童装</li>
  <li>手机会场</li>
  <li>美妆会场</li>
  <li>家居建材</li>
  <li>进口会场</li>
  <li>飞猪旅行</li>
  </ul>
 </nav>

 <script>
 window.onload = function () {
  var nav = $('nav');
  var t_mall = nav.children[0];
  var ul = nav.children[1];
  var allLis = ul.children;
  var beginX = 0;

  for (var i = 0; i < allLis.length; i++) {
  var li = allLis[i];
  li.onmouseover = function () {
   end = this.offsetLeft;
  }

  li.onmousedown = function () {
   beginX = this.offsetLeft;
  }

  li.onmouseout = function () {
   end = beginX;
  }
  }

  var begin = 0, end = 0;
  setInterval(function () {
  begin = begin + (end - begin) / 10;
  t_mall.style.left = begin + 'px';
  }, 10)

  function $(id) {
  return typeof id ? document.getElementById(id) : null;
  }
 }
 </script>
</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
文本加密解密
Jun 23 Javascript
JavaScript中实现PHP的打乱数组函数shuffle实例
Oct 11 Javascript
JS、jQuery中select的用法详解
Apr 21 Javascript
Three.js学习之几何形状
Aug 01 Javascript
bootstrap IE8 兼容性处理
Mar 22 Javascript
javascript编程实现栈的方法详解【经典数据结构】
Apr 11 Javascript
详解如何配置vue-cli3.0的vue.config.js
Aug 23 Javascript
小程序实现展开/收起的效果示例
Sep 22 Javascript
JS实现随机生成10个手机号的方法示例
Dec 07 Javascript
JS实现简单的文字无缝上下滚动功能示例
Jun 22 Javascript
原生JavaScript实现滑动拖动验证的示例代码
Dec 06 Javascript
微信小程序之滑动页面隐藏和显示组件功能的实现代码
Jun 19 Javascript
JavaScript实现缓动动画
Nov 25 #Javascript
Vue3配置axios跨域实现过程解析
Nov 25 #Vue.js
Vue使用Element实现增删改查+打包的步骤
Nov 25 #Vue.js
JavaScript实现网页动态生成表格
Nov 25 #Javascript
vue + el-form 实现的多层循环表单验证
Nov 25 #Vue.js
JavaScript实现HTML导航栏下拉菜单
Nov 25 #Javascript
vue打开其他项目页面并传入数据详解
Nov 25 #Vue.js
You might like
php下的权限算法的实现
2007/04/28 PHP
PHP7.0版本备注
2015/07/23 PHP
学习php设计模式 php实现访问者模式(Visitor)
2015/12/07 PHP
再谈PHP中单双引号的区别详解
2016/06/12 PHP
Yii2下点击验证码的切换实例代码
2017/03/14 PHP
PHP DB 数据库连接类定义与用法示例
2019/03/11 PHP
PHP写API输出的时用echo的原因详解
2019/04/28 PHP
jquery 简单导航实现代码
2009/09/11 Javascript
javascript parseInt 大改造
2009/09/27 Javascript
分享20多个很棒的jQuery 文件上传插件或教程
2011/09/04 Javascript
基于OO的动画附加插件,可以实现弹跳、渐隐等动画效果 分享
2013/06/24 Javascript
javascript中取前n天日期的两种方法分享
2014/01/26 Javascript
javascript生成大小写字母
2015/07/03 Javascript
JavaScript取得键盘按下方向键是哪个的方法
2015/08/04 Javascript
清除js缓存的多种方法总结
2016/12/09 Javascript
详解使用grunt完成requirejs的合并压缩和js文件的版本控制
2017/03/02 Javascript
你有必要知道的10个JavaScript难点
2017/07/25 Javascript
JavaScript引用类型Array实例分析
2018/07/24 Javascript
JS前端知识点offset,scroll,client,冒泡,事件对象的应用整理总结
2019/06/27 Javascript
[03:03]DOTA2 2017国际邀请赛开幕战队入场仪式
2017/08/09 DOTA
在Python下使用Txt2Html实现网页过滤代理的教程
2015/04/11 Python
Python使用pyodbc访问数据库操作方法详解
2018/07/05 Python
python交互界面的退出方法
2019/02/16 Python
对pyqt5中QTabWidget的相关操作详解
2019/06/21 Python
Python列表(list)所有元素的同一操作解析
2019/08/01 Python
详解Python可视化神器Yellowbrick使用
2019/11/11 Python
TensorFlow tf.nn.max_pool实现池化操作方式
2020/01/04 Python
TensorFlow实现指数衰减学习率的方法
2020/02/05 Python
Python特殊属性property原理及使用方法解析
2020/10/09 Python
平面设计自荐信
2013/10/07 职场文书
公司授权委托书
2014/04/04 职场文书
2014年教研活动总结范文
2014/04/26 职场文书
减负增效提质方案
2014/05/23 职场文书
2014年数学教研组工作总结
2014/12/06 职场文书
PHP判断是否是json字符串
2021/04/01 PHP
React实现动效弹窗组件
2021/06/21 Javascript