javascript实现左右缓动动画函数


Posted in Javascript onNovember 25, 2020

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

<!DOCTYPE html>
<html>
 <head>
 <meta charset="utf-8">
 <link rel="stylesheet" href="bootstrap-4.4.1.css" >
 <style>
 
 .box{
 width: 100px;
 height: 100px;
 background-color: chartreuse;
 position:absolute;
 }
 </style>
 </head>
 <body>

 <button class="btn1">移动400px</button>
 <button class="btn2">移动800px</button>
 <div class="box"></div>

 <script>

 let btn1 = document.querySelector('.btn1');
 let btn2 = document.querySelector('.btn2');
 let box = document.querySelector('.box');

 btn1.onclick = function(){
 animate(box,400);
 }

 btn2.onclick = function(){
 animate(box,800);
 }

 // 缓动动画
 function animate(element,target){
 // 清除定时器
 clearInterval(element.timeId);

 element.timeId = setInterval(function(){
  // 获取元素当前的位置
  let current = element.offsetLeft;
  // 当current越大,step越小,先快后慢
  let step = (target - current) / 10;
  // 当step大于0时,step向上取整,否则,step向下取整
  step = step > 0 ? Math.ceil(step) : Math.floor(step);
  current += step;
  element.style.left = current + 'px';
  // 不用担心到达不了目标位置,因为step最小达到1
  if(current == target){
  clearInterval(element.timeId);
  }
  console.log("目标位置:" + target + "当前位置:" + current + "每次移动的步数:" + step);
 },20);
 }

 </script>
 
 </body>
</html>

javascript实现左右缓动动画函数

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

Javascript 相关文章推荐
Add a Picture to a Microsoft Word Document
Jun 15 Javascript
解决火狐浏览器下JS setTimeout函数不兼容失效不执行的方法
Nov 14 Javascript
JavaScript在XHTML中的用法详解
Apr 11 Javascript
在js文件中写el表达式取不到值的原因及解决方法
Dec 23 Javascript
高性能JavaScript DOM编程(1)
Aug 11 Javascript
js弹出窗口简单实现代码
Mar 22 Javascript
Angularjs中ng-repeat的简单实例
Aug 25 Javascript
jQuery中将json数据显示到页面表格的方法
May 27 jQuery
小程序实现页面顶部选项卡效果
Nov 06 Javascript
详解TypeScript+Vue 插件 vue-class-component的使用总结
Feb 18 Javascript
微信小程序绑定手机号获取验证码功能
Oct 22 Javascript
微信小程序实现底部弹出框
Nov 18 Javascript
JavaScript缓动动画函数的封装方法
Nov 25 #Javascript
js实现缓动动画
Nov 25 #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
You might like
《PHP编程最快明白》第五讲:php目录、文件操作
2010/11/01 PHP
php数组中删除元素的实现代码
2012/06/22 PHP
Laravel学习教程之View模块详解
2017/09/18 PHP
解决Laravel5.2 Auth认证退出失效的问题
2019/10/14 PHP
JSON JQUERY模板实现说明
2010/07/03 Javascript
jquery ajax例子返回值详解
2012/09/11 Javascript
深入分析JSON编码格式提交表单数据
2015/06/25 Javascript
实例解析JS布尔对象的toString()方法和valueOf()方法
2015/10/25 Javascript
高效利用Angular中内置服务$http、$location等
2016/03/22 Javascript
jQuery设置Cookie及删除Cookie实例分析
2016/04/15 Javascript
Jquery表单验证失败后不提交的解决方法
2016/10/18 Javascript
利用HTML5+Socket.io实现摇一摇控制PC端歌曲切换
2017/01/13 Javascript
关于vue.js组件数据流的问题
2017/07/26 Javascript
JS实现的视频弹幕效果示例
2018/08/17 Javascript
浅谈vue限制文本框输入数字的正确姿势
2019/09/02 Javascript
微信小程序中限制激励式视频广告位显示次数(实现思路)
2019/12/06 Javascript
解决vue组件没显示,没起作用,没报错,但该显示的组件没显示问题
2020/09/02 Javascript
jquery实现穿梭框功能
2021/01/19 jQuery
详解python string类型 bytes类型 bytearray类型
2017/12/16 Python
Python玩转Excel的读写改实例
2019/02/22 Python
python requests使用socks5的例子
2019/07/25 Python
torch 中各种图像格式转换的实现方法
2019/12/26 Python
详解python实现可视化的MD5、sha256哈希加密小工具
2020/09/14 Python
python中的垃圾回收(GC)机制
2020/09/21 Python
Python引入多个模块及包的概念过程解析
2020/09/21 Python
关于Python错误重试方法总结
2021/01/03 Python
购买原创艺术品:Zatista
2019/11/09 全球购物
卡拉威高尔夫官方网站:Callaway Golf
2020/09/16 全球购物
区域销售经理职责
2013/12/22 职场文书
化妆师职业生涯规划书
2014/02/16 职场文书
销售人员职业生涯规划范文
2014/03/01 职场文书
如何撰写一封出色的求职信
2014/04/27 职场文书
管理提升方案
2014/06/04 职场文书
基层干部群众路线教育实践活动个人对照检查材料
2014/09/23 职场文书
幼儿园中班班级总结
2015/08/10 职场文书
Nginx报404错误的详细解决方法
2022/07/23 Servers