概述
在原生JS的使用中,我们经常会利用定时器setInterval、clearInterval配合position的定位来实现动画。于是就产生了将动画函数封装的想法,最开始的move函数如下(又不是不能用!!!)
function move(obj, target, speed, dir, callback) {
//添加定时器前为清除之前的定时器
clearInterval(obj.timer);
/*
参数: 1.事件绑定对象
2.移动的目标位置
3.移动的速度
4.需要移动的方向dir,或者是需要改变的样式
5.加入回调函数,当前定时器完成后执行的函数
*/
//获取当前位置和目标位置的距离,判断移动方向
var current = parseInt(getStyle(obj, dir));
if (target < current) {
speed = -speed;
}
//添加定时器
obj.timer = setInterval(function() {
var oldValue = parseInt(getStyle(obj, dir));
var newValue = oldValue + speed;
if ((target < newValue && speed > 0) || (target > newValue && speed < 0)) {
newValue = target;
}
obj.style[dir] = newValue + "px";
//到达终点后清除定时器
if (newValue === target) {
clearInterval(obj.timer);
//执行完毕后执行回调函数,如果没有回调函数则不执行
callback && callback();
}
}, 30);
};
//获取节点样式的函数getStyle
function getStyle(obj, name) {
if (window.getComputedStyle) {
return getComputedStyle(obj, null)[name];
} else {
return obj.currentStyle[name];
}
}
move函数动画的不足
- 样式的改变只能是链式的,只能通过回调函数进行链式操作
- 动画的运动速率是恒定的,看起来比较生硬
- 函数的参数太多,调用的时候记不住
move函数的改进版animation函数
function animation(obj2, json, callback2) {
/*
obj:需要添加动画的对象
json: 封装需要改变obj样式的目标属性
callback:动画执行完毕后的回调函数
为了区分move函数中的变量,故采用2的方式
*/
var num = 0;//方便统计是否完全执行完json中的内容
var total = Object.keys(json).length;//确定json属性值得个数,配合计数器num判断清除定时器的时间
var speed2 = 0; //设置初速度为0
//添加定时器之前清除定时器
clearInterval(obj2.timer);
obj2.timer = setInterval(function() {
//遍历json中封装的各个属性
for (var property in json) {
var curentProperty = null;
if (property == "opacity") {
//如果获取的属性时透明度,需要将其扩大100倍方便进行整数计算
curentProperty = Math.round(parseFloat(getStyle(obj2, property)) * 100)
} else {
curentProperty = parseInt(getStyle(obj2, property)); //因为获取其他有单位的需要转换为整数,然后进行计算
}
//进行速度的设置
var speed2 = (json[property] - curentProperty) / 10;//实现由快到慢的缓动
//进行速度的取整设置,如果不取整,则无法到达目标动画位置
if (speed2 > 0) {
speed2 = Math.ceil(speed2); //如果速度速度大于0 就向上取整
} else {
speed2 = Math.floor(speed2); //负数需要向下取整,不能出现倒车
}
if(json[property] === curentProperty){
num ++;
delete json[property];
}else {
if (property == "opacity") {
obj2.style.filter = 'alpha(opacity=' + (curentProperty + speed2) + ')';
obj2.style.opacity = (curentProperty + speed2) / 100;
} else {
obj2.style[property] = curentProperty + speed2 + "px";
}
}
}
if (num === total) {
clearInterval(obj2.timer);
callback2 && typeof callback2 === 'function' && callback2();
}
}, 30);
};
不得不说我是站在巨人的肩膀上,在写animation函数之前参考了别人的思想,比如实现缓动等。但是发现很多人写的都有bug,比如回调函数无法回调等等。如果你发现本代码有bug,请不要吝啬你的宝贵意见,欢迎评论探讨。
参考文章
最后
以上就是美满唇彩为你收集整理的原生JS简单动画函数的全部内容,希望文章能够帮你解决原生JS简单动画函数所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复