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 相关文章推荐
JS和JQUERY获取页面大小,滚动条位置,元素位置(示例代码)
Dec 14 Javascript
前台js对象在后台转化java对象的问题探讨
Dec 20 Javascript
浅析JavaScript动画
Jun 10 Javascript
javascript记住用户名和登录密码(两种方式)
Aug 04 Javascript
JavaScript的面向对象编程基础
Aug 13 Javascript
基于javascript制作经典传统的拼图游戏
Mar 22 Javascript
jQuery中$.grep() 过滤函数 数组过滤
Nov 22 Javascript
vue源码解析之事件机制原理
Apr 21 Javascript
element-ui表格数据转换的示例代码
Aug 24 Javascript
使用electron制作满屏心特效的示例代码
Nov 27 Javascript
Seajs源码详解分析
Apr 02 Javascript
vue二维数组循环嵌套方式 循环数组、循环嵌套数组
Apr 24 Vue.js
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
substr()函数中文版
2006/10/09 PHP
服务器端解压缩zip的脚本
2006/12/22 PHP
apache+codeigniter 通过.htcaccess做动态二级域名解析
2012/07/01 PHP
谈谈关于php的优点与缺点
2013/04/11 PHP
利用PHP实现短域名互转
2013/07/05 PHP
php读取富文本的时p标签会出现红线是怎么回事
2014/05/13 PHP
合并ThinkPHP配置文件以消除代码冗余的实现方法
2014/07/22 PHP
php实现统计目录文件大小的函数
2015/12/25 PHP
实例讲解PHP中使用命名空间
2019/01/27 PHP
php获取是星期几的的一些常用姿势
2019/12/15 PHP
PHP大文件及断点续传下载实现代码
2020/08/18 PHP
使用JS操作页面表格,元素的一些技巧
2007/02/02 Javascript
JQuery的ajax获取数据后的处理总结(html,xml,json)
2010/07/14 Javascript
Javascript 修改String 对象 增加去除空格功能(示例代码)
2013/11/30 Javascript
node.js使用require()函数加载模块
2014/11/26 Javascript
js分页工具实例
2015/01/28 Javascript
浅析JS动态创建元素【两种方法】
2016/04/20 Javascript
第一次接触Bootstrap框架
2016/10/24 Javascript
vue 右键菜单插件 简单、可扩展、样式自定义的右键菜单
2018/11/29 Javascript
vue 授权获取微信openId操作
2020/11/13 Javascript
[01:08:43]DOTA2-DPC中国联赛定级赛 Phoenix vs DLG BO3第一场 1月9日
2021/03/11 DOTA
Python调用SQLPlus来操作和解析Oracle数据库的方法
2016/04/09 Python
下载python中Crypto库报错:ModuleNotFoundError: No module named ‘Crypto’的解决
2018/04/23 Python
linux下python使用sendmail发送邮件
2018/05/22 Python
Python制作微信好友背景墙教程(附完整代码)
2019/07/17 Python
selenium切换标签页解决get超时问题的完整代码
2020/08/30 Python
澳大利亚最大的网上油画销售画廊:Direct Art Australia
2018/04/15 全球购物
法国在线购买汽车轮胎网站:123pneus.fr
2019/02/25 全球购物
欧洲最大的高尔夫零售商:American Golf
2019/09/02 全球购物
Linux内核的同步机制是什么?主要有哪几种内核锁
2016/07/11 面试题
如何写出高质量、高性能的MySQL查询
2014/11/17 面试题
体育运动口号
2014/06/09 职场文书
2014年专项整治工作总结
2014/11/17 职场文书
python实现socket简单通信的示例代码
2021/04/13 Python
基于go interface{}==nil 的几种坑及原理分析
2021/04/24 Golang
HTML+CSS实现导航条下拉菜单的示例代码
2021/08/02 HTML / CSS