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 相关文章推荐
JavaScript之appendChild、insertBefore和insertAfter使用说明
Dec 30 Javascript
通过JS获取用户本地图片路径并显示的代码
Feb 16 Javascript
JavaScript数组去重的3种方法和代码实例
Jul 01 Javascript
jquery实现漫天雪花飞舞的圣诞祝福雪花效果代码分享
Aug 20 Javascript
Javascript小技能总结(推荐)
Jun 02 Javascript
js 弹出虚拟键盘修改密码的简单实例
Oct 10 Javascript
vue中v-text / v-html使用实例代码详解
Apr 02 Javascript
JavaScript中Dom操作实例详解
Jul 08 Javascript
从零撸一个pc端vue的ui组件库( 计数器组件 )
Aug 08 Javascript
vue自动化路由的实现代码
Sep 30 Javascript
基于javascript canvas实现五子棋游戏
Jul 08 Javascript
Node与Python 双向通信的实现代码
Jul 16 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
Zend Framework框架教程之Zend_Db_Table_Rowset用法实例分析
2016/03/21 PHP
PHP带节点操作的无限分类实现方法详解
2016/11/09 PHP
php使用flock阻塞写入文件和非阻塞写入文件的实例讲解
2017/07/10 PHP
layui框架实现文件上传及TP3.2.3(thinkPHP)对上传文件进行后台处理操作示例
2018/05/12 PHP
php 与 nginx 的处理方式及nginx与php-fpm通信的两种方式
2018/09/28 PHP
PHP递归算法的简单实例
2019/02/28 PHP
js prototype截取字符串函数
2010/04/01 Javascript
js data日期初始化的5种方法
2013/12/29 Javascript
jQuery实现鼠标划过添加和删除class的方法
2015/06/26 Javascript
谈谈JavaScript类型系统之Math
2016/01/06 Javascript
Vuejs第九篇之组件作用域及props数据传递实例详解
2016/09/05 Javascript
使用JS正则表达式 替换括号,尖括号等
2016/11/29 Javascript
JavaScript中双符号的运算详解
2017/03/12 Javascript
JS实现给json数组动态赋值的方法示例
2020/03/19 Javascript
Three.js利用dat.GUI如何简化试验流程详解
2017/09/26 Javascript
JS实现水平遍历和嵌套递归操作示例
2019/08/15 Javascript
TensorFlow.js 微信小程序插件开始支持模型缓存的方法
2020/02/21 Javascript
nginx配置域名后的二级目录访问不同项目的配置操作
2020/11/06 Javascript
Vue中引入svg图标的两种方式
2021/01/14 Vue.js
动感网页相册 python编写简单文件夹内图片浏览工具
2016/08/17 Python
Django框架模型简单介绍与使用分析
2019/07/18 Python
python实现的爬取电影下载链接功能示例
2019/08/26 Python
Spring实战之使用util:命名空间简化配置操作示例
2019/12/09 Python
Python Flask异步发送邮件实现方法解析
2020/08/01 Python
pip已经安装好第三方库但pycharm中import时还是标红的解决方案
2020/10/09 Python
html5的画布canvas——画出弧线、旋转的图形实例代码+效果图
2013/06/09 HTML / CSS
使用canvas实现黑客帝国数字雨效果
2020/01/02 HTML / CSS
Skyscanner阿联酋:全球领先的旅游搜索平台
2017/11/25 全球购物
重写子类方法时,抛出异常的书写注意事项
2015/10/17 面试题
应届生英语教师求职信
2013/11/05 职场文书
超市采购员岗位职责
2014/02/01 职场文书
酒店周年庆活动方案
2014/08/21 职场文书
门店店长岗位职责
2015/04/14 职场文书
国家助学金受助感言
2015/08/01 职场文书
Matplotlib绘制混淆矩阵的实现
2021/05/27 Python
Go归并排序算法的实现方法
2022/04/06 Golang