JS运动改变单物体透明度的方法分析
本文实例讲述了JS运动改变单物体透明度的方法。分享给大家供大家参考,具体如下:
除了通过改变物体的 宽,高,letf,top位置或者是运动方向来实现物体运动效果之外,改变物体的透明度,也是运动特效
<script>
window.onload = function () {
var oDiv = document.getElementById('div1');
oDiv.onmousemove = function () {
startMove(100);
}
oDiv.onmouseout = function () {
startMove(30);
}
}
var timer = null;
function startMove(iTarget) {
clearInterval(timer);
var oDiv = document.getElementById('div1');
timer = setInterval(function(){
if(oDiv.offsetAlpha == iTarget){
....
}
},30);
}
</script>
但是在js中只有offsetLeft/Top ,offsetWidth/Height,这四个方法,并没有offsetAlpha这个方法。
问:那么我们怎么来 获取当前物体的透明度那??
我们可以自己定义一个变量 var alpha = 30;通过判断这个变量 是否和目标值是否相等,来继续我们下一步的操作;
var alpha = 30; // 自定义一个变量
当alpha 等目标值得时候,清楚定时器,否则就改变透明度的值alpha
if(alpha == iTarget){
clearInterval(timer);
}else{
alpha += iSpeed;
oDiv.style.opacity = alpha/100;
oDiv.style.filter = 'alpha(opacity:'+alpha+')';
}
完整的代码如下:
<div id="div1"></div>
css样式部分:
<style>
#div1{
width: 100px;height: 100px;
background: green;
opacity:0.3;
filter:alpha(opacity:30);/*兼容低版本IE*/
}
</style>
js部分:
<script>
window.onload = function () {
var oDiv = document.getElementById('div1');
oDiv.onmousemove = function () {
startMove(100);
}
oDiv.onmouseout = function () {
startMove(30);
}
}
var timer = null;
var alpha = 30;
function startMove(iTarget) {
clearInterval(timer);
var oDiv = document.getElementById('div1');
var iSpeed = 0;
timer = setInterval(function(){
if(alpha>iTarget){
iSpeed = -10;
}else{
iSpeed = 10;
}
if(alpha == iTarget){
clearInterval(timer);
}else{
alpha += iSpeed;
oDiv.style.opacity = alpha/100;
oDiv.style.filter = 'alpha(opacity:'+alpha+')';
}
},30);
}
</script>
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript切换特效与技巧总结》、《JavaScript动画特效与技巧汇总》、《JavaScript查找算法技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》、《JavaScript中json操作技巧总结》、《JavaScript错误与调试技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。
相关文章
控制台报错:Cannot access 'xxx' before initializatio
这篇文章主要给大家介绍了关于控制台报错:Cannot access 'xxx' before initialization的解决方法,文中通过代码介绍的非常详细,对大家的学习或者工作具有一定的参考借鉴价值,需要的朋友可以参考下2023-11-11
使用layui监听器监听select下拉框,事件绑定不成功的解决方法
今天小编就为大家分享一篇使用layui监听器监听select下拉框,事件绑定不成功的解决方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2019-09-09
移动端翻页插件dropload.js(支持Zepto和jQuery)
这篇文章主要为大家详细介绍了移动端翻页插件dropload.js,支持Zepto和jQuery,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2016-07-07
微信小程序实现上传word、txt、Excel、PPT等文件功能
这篇文章主要为大家详细介绍了微信小程序实现上传word、txt、Excel、PPT等文件功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2019-05-05


最新评论