bluesy
2016-01-05 16:18
function getStyle(obj,attr){
if(obj.currentStyle){
return obj.currentStyle[attr]; //IE浏览器
}
else{
return getComputedStyle(obj,false)[attr];//火狐浏览器
}
}
如果变宽和变高都可以实现的话,有可能是透明度改变的那一部分代码写错了,或者是你用的浏览器不兼容吧;
ie,edge,opera应该都是用的currentstyle,其他的用的都是getcomputedstyle
宽和高都能实现,就是透明度有问题呀,麻烦你帮我看看是什么地方出问题了,谢谢
function getStyle(obj,attr){
if(obj.currentStyle){
return obj.currentStyle[attr]; //IE浏览器
}
else{
return getComputedStyle(obj,false)[attr];//火狐浏览器
}
}
function startMove(obj,attr,target,fn){//(fn是一个为回调函数)
clearInterval(obj.timer);
obj.timer=setInterval(function(){
//1.取当前的值
var icur = 0;
if(attr == 'opacity'){
/*是否为透明度的判断*/
icur = Math.round(parseFloat(getStyle(obj.attr))*100);
}
else{
icur=parseInt(getStyle(obj,attr));
}
//2.算速度
var speed =(target-icur)/8;
speed = speed > 0?Math.ceil(speed):Math.floor(speed);
//3.检测停止
if(icur == target){
clearInterval(obj.timer);
if(fn){
fn()
}
}
else{
if(attr == 'opacity'){
<!--针对IE浏览器-->
obj.style.filter = 'alpha:(opacity:'+(icur + speed)+')';
<!--针对火狐或者谷歌浏览器-->
obj.style.opacity = (icur +speed)/100;
}
else{
obj.style[attr]= icur + speed +'px';<!--(透明度不加PX的)-->
}
}
},30)
}
JS动画效果
113925 学习 · 1443 问题
相似问题
回答 5
回答 2