animate dong

本文介绍了一个使用JavaScript实现的简单动画效果案例。通过监听按钮点击事件触发动画,利用定时器逐步改变元素的位置,实现了平滑过渡至指定位置的效果。文章详细展示了如何通过代码控制动画的速度与方向,并解决了动画过程中可能出现的抖动问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >




btn2.onclick = function() {
    animate(box,400);
}
 // 自定义属性   object
//  基本封装
function animate(obj,target) {
    clearInterval(obj.timer);  // 要开启定时器,先清除以前定时器
 // 2个参数 第一个 对象谁做动画  第二 距离 到哪里

    obj.timer = setInterval(function() {
        // 如果 offsetLeft 大于了  target 目标位置就应该反方向
        var speed = obj.offsetLeft < target ? 10 : -10;
        var result = target - obj.offsetLeft;  //  他们的值 等于 0 说明完全相等
        // 动画的原理
        obj.style.left = obj.offsetLeft + speed  + "px";
        if(Math.abs(result) == 0) {
           obj.style.left = target + "px";   //抖动问题
            clearInterval(obj.timer);
        }
    },30);
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值