js运动函数封装

运动函数封装

思路:

首先我们做想要做一个效果出来,得先分析这个效果需要涉及什么:

1. 先看看思路图:

在这里插入图片描述

2. 上图得知:我们想要运动,需要有什么变量:
  • dom对象
  • 初始值(我这里只对left进行操作,后期完善再修改)
  • 步长
  • 时间间隔
  • 目标值
3. 代码展现
/*
*	autoRun():
*		ele:要运动的dom对象
*		start: 初始值
*		step:步长
*		everyTime: 时间间隔
*		target:目标值
*		(如果你想要定时器执行完一次后,)
*/
function autoRun(ele, step = 10, target, everyTime = 30) {
     /*这里传入的ele是一个对象,为对象添加了一个属性存储定时器ID。 
     因为这种方式底层是以内存地址引用的
     所以这里的属性会被全局保存下来*/
     let start = ele.offsetLeft;
     clearInterval(ele.timer);
     ele.timer = setInterval(() => {
         start += target > start ? step : -step;
         if (Math.abs(target - start) > Math.abs(step)) {
             ele.style.left = start + "px";
         } else {
             ele.style.left = target + "px";
         }
         clearInterval(ele.timer);
     }, everyTime);
 }
    </script>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值