js html 渐变透明度,用js实现透明度渐变效果

如图,一开始元素的透明度是30,鼠标移上的时候,透明度慢慢增加,到透明度100停止。鼠标移出,透明度慢慢减少,减少到30.

9735f2a0d9eb6b514067ba714d7d2b84.png

要点一:因为无法直接获取和改变透明度的值,可以把透明度值赋给一个变量,让变量变化,最后把变量的值再赋给元素的透明值。

var alpha=30;

要点二:判断目标值和目前透明值,来判定是正向速度还是负向速度。

if(target > alpha){

speed = 2;

}else{

speed = -2;

}

要点三:如果透明值达到目标值,关掉定时器,否则透明值继续变化。最后把值赋给元素,因为透明度有兼容问题,所以要写上两个写法。

if(alpha == target){

clearInterval(timer);

}

else{

alpha = alpha + speed;

run.style.filter = 'alpha(opacity='+alpha+')';

run.style.opacity = alpha/100;

document.title = alpha;

}

最后,上代码

69c5a8ac3fa60e0848d784a6dd461da6.png

无标题文档

run.οnmοuseοver= function(){

startrun(100);

}

run.οnmοuseοut= function(){

startrun(30);

}functionstartrun(target){

clearInterval(timer);

timer=setInterval(function(){if(target>alpha){

speed= 2;

}else{

speed= -2;

}if(alpha==target){

clearInterval(timer);

}else{

alpha=alpha+speed;

run.style.filter= 'alpha(opacity='+alpha+')';

run.style.opacity=alpha/100;document.title=alpha;

}

},30)

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值