当前位置:首页 » 操作系统 » js动画算法

js动画算法

发布时间: 2024-09-17 21:12:18

⑴ js实现匀速下落动画怎么实现

/*
data:2022-11-17
author:lfp
move运动函数
dom--需要运动的对象
json--{width:100,height:100,left:100,top:100}
callback--回调函数 可调用自己 实现异步动画效果
*/
//主函数
function move(dom,json,callback){
//让每一次动画都是新的开始,防止出现动画一直不停的运行
if(dom.timer)clearInterval(dom.timer);
var i=0;
var start=0;
//在对象中增加timer 便于控制他停止
dom.timer=setInterval(function(){
i++;
//循环每一个目标属性添加动画方法
for(var attr in json){
//获取当前attr的属性值 已经去除了px 还有 如果初始值是auto 用零代替
var cur=getStyle(dom,attr);
if(i==1)start=cur;
//拿到该属性的目标值
var target=json[attr];
//设置分成10次增加增量 你可以根据需要修改
var speed=(target-start)/10;
console.log(speed+"====="+cur)
//如果没有达到目标值就一直加
if(Math.abs(cur-target)>1){
dom.style[attr]=cur+speed+"px";
}else{
//达到目标值了就停止或者其他情况也停止
clearInterval(dom.timer);
//等停止了动画再回调函数进行另外的操作
if(callback)callback.call(dom);
};
};
},45);
};
//配套函数
function getStyle(dom,attr){
var value="";
if(window.getComputedStyle){
value=window.getComputedStyle(dom,false)[attr];
}else{
value=dom.currentStyle[attr];
};
value=parseInt(value);
return value || 0;//如果你再样式中没有设置初始的值就会出现NaN 所以要用0来补充
};
function $(id){
//return document.getElementById(id);
return document.querySelector("#"+id);
};

热点内容
什么安卓手机全方面可以超过苹果 发布:2024-11-24 20:30:35 浏览:800
面窝麻将脚本 发布:2024-11-24 20:29:16 浏览:234
安卓手机处理器八核是什么意思 发布:2024-11-24 20:29:11 浏览:175
安卓手机怎么内录直播 发布:2024-11-24 20:29:08 浏览:894
3d脚本反编译 发布:2024-11-24 20:27:09 浏览:56
思域哪个配置最好看 发布:2024-11-24 20:26:20 浏览:713
少年绘编程 发布:2024-11-24 20:07:04 浏览:311
联想电脑授权服务器在哪 发布:2024-11-24 19:56:37 浏览:309
steam服务器为什么炸了 发布:2024-11-24 19:45:32 浏览:570
加密狗在电脑 发布:2024-11-24 19:43:44 浏览:66