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 相关文章推荐
js脚本学习 比较实用的基础
Sep 07 Javascript
JQuery+JS实现仿百度搜索结果中关键字变色效果
Aug 02 Javascript
JavaScript动态加载样式表的方法
Mar 21 Javascript
jquery中live()方法和bind()方法区别分析
Jun 23 Javascript
浅谈js中startsWith 函数不能在任何浏览器兼容的问题
Mar 01 Javascript
vue高德地图之玩转周边
Jun 16 Javascript
一个简易的js图片轮播效果
Jul 22 Javascript
利用原生js实现html5小游戏之打砖块(附源码)
Jan 03 Javascript
图文讲解用vue-cli脚手架创建vue项目步骤
Feb 12 Javascript
vue路由守卫及路由守卫无限循环问题详析
Sep 05 Javascript
Jquery Datatables的使用详解
Jan 30 jQuery
Vue.js中Line第三方登录api的实现代码
Jun 29 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
PHP5/ZendEngine2的改进
2006/10/09 PHP
使用 MySQL 开始 PHP 会话
2006/12/21 PHP
php牛逼的面试题分享
2013/01/18 PHP
PHP中echo和print的区别
2014/08/28 PHP
CodeIgniter钩子用法实例详解
2016/01/20 PHP
CI框架整合widget(页面格局)的方法
2016/05/17 PHP
PHP实现一个简单url路由功能实例
2016/11/05 PHP
基于jQuery的一个扩展form序列化到json对象
2010/12/09 Javascript
JS 实现Json查询的方法实例
2013/04/12 Javascript
JavaScript Ajax Json实现上下级下拉框联动效果实例代码
2013/11/23 Javascript
JavaScript学习小结(一)——JavaScript入门基础
2015/09/02 Javascript
jQuery插件form-validation-engine正则表达式操作示例
2017/02/09 Javascript
AngularJS入门教程二:在路由中传递参数的方法分析
2017/05/27 Javascript
基于Vue-cli快速搭建项目的完整步骤
2018/11/03 Javascript
微信小程序车牌号码模拟键盘输入功能的实现代码
2018/11/11 Javascript
javascript原型链学习记录之继承实现方式分析
2019/05/01 Javascript
浅谈vue中组件绑定事件时是否加.native
2019/11/09 Javascript
Javascript实现鼠标点击冒泡特效
2019/12/24 Javascript
vue elementui 实现搜索栏公共组件封装的实例代码
2020/01/20 Javascript
深入解析Python中的__builtins__内建对象
2016/06/21 Python
Python爬取当当、京东、亚马逊图书信息代码实例
2017/12/09 Python
python redis 删除key脚本的实例
2019/02/19 Python
Python3网络爬虫中的requests高级用法详解
2019/06/18 Python
Python使用Opencv实现边缘检测以及轮廓检测的实现
2020/12/31 Python
css3 仿写阿里云水纹效果的示例代码
2018/02/10 HTML / CSS
AmazeUI框架搭建的方法步骤(图文)
2020/08/17 HTML / CSS
加拿大折扣、优惠券和交易网站:WagJag
2018/02/07 全球购物
爱尔兰电子产品购物网站:Komplett.ie
2018/04/04 全球购物
个人自我鉴定
2013/11/07 职场文书
优乐美广告词
2014/03/14 职场文书
党建工作经验交流材料
2014/05/25 职场文书
党的群众路线教育实践活动对照检查材料(四风)
2014/09/27 职场文书
成本会计实训报告
2014/11/05 职场文书
2015年教师新年寄语
2014/12/08 职场文书
告诉你创业计划书的8个实用技巧
2019/07/12 职场文书
宫崎骏十大动画电影,宫崎骏好看的动画电影排名
2022/03/22 日漫