js运动技术--多物体同时运动
2017-07-13 08:06
169 查看
注意:每个物体需要单独使用一个定时器
样例1:多个div变宽
样例2:多个div淡入淡出:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
<style>
div{height: 200px;width: 200px;background: red;margin: 20px;float: left;
filter: alpha(opacity:30);opacity: 0.3;}
</style>
<script>
window.onclick = function(){
var aDiv = document.getElementsByTagName("div");
for(var i = 0; i < aDiv.length; i++){
aDiv[i].timer = null;
aDiv[i].alpha = 30;
aDiv[i].onmouseover = function(){
startMove(this,100);
}
aDiv[i].onmouseout = function(){
startMove(this,30);
}
}
}
function startMove(obj,iTarget){
clearInterval(obj.timer);
obj.timer = setInterval(function(){
var speed = (iTarget - obj.alpha)/6;
speed = speed > 0 ? Math.ceil(speed) : Math.floor(speed);
if(obj.alpha == iTarget){
clearInterval(obj.timer);
}
else {
obj.alpha += speed;
obj.style.filter = 'alpha(opacity'+obj.alpha+')';
obj.style.opacity = obj.alpha / 100;
}
},30);
}
</script>
</head>
<body>
<div></div>
<div></div>
<div></div>
<div></div>
</body>
</html>
从两个例子可以看出:对于多物体运动来说,不能使用公用的参数,可以通过添加属性来完成。
样例1:多个div变宽
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title></title> <style> div {height: 50px;width: 100px;background: red;margin: 10px;} </style> <script> window.onclick =function(){ var aDiv =document.getElementsByTagName("div"); for(var i = 0; i < aDiv.length; i++){ aDiv[i].timer = null; aDiv[i].onmouseover = function(){ startMove(this,400); } aDiv[i].onmouseout = function(){ startMove(this,100); } } } function startMove (obj,iTarget){ clearInterval(obj.timer); obj.timer = setInterval(function(){ if(obj.offsetWidth == iTarget){ clearInterval(obj.timer); } else { var speed = (iTarget - obj.offsetWidth) / 6; speed = speed > 0 ? Math.ceil(speed) : Math.floor(speed); obj.style.width = obj.offsetWidth + speed + 'px'; } },30); } </script> </head> <body> <div></div> <div></div> <div></div> </body> </html>
样例2:多个div淡入淡出:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
<style>
div{height: 200px;width: 200px;background: red;margin: 20px;float: left;
filter: alpha(opacity:30);opacity: 0.3;}
</style>
<script>
window.onclick = function(){
var aDiv = document.getElementsByTagName("div");
for(var i = 0; i < aDiv.length; i++){
aDiv[i].timer = null;
aDiv[i].alpha = 30;
aDiv[i].onmouseover = function(){
startMove(this,100);
}
aDiv[i].onmouseout = function(){
startMove(this,30);
}
}
}
function startMove(obj,iTarget){
clearInterval(obj.timer);
obj.timer = setInterval(function(){
var speed = (iTarget - obj.alpha)/6;
speed = speed > 0 ? Math.ceil(speed) : Math.floor(speed);
if(obj.alpha == iTarget){
clearInterval(obj.timer);
}
else {
obj.alpha += speed;
obj.style.filter = 'alpha(opacity'+obj.alpha+')';
obj.style.opacity = obj.alpha / 100;
}
},30);
}
</script>
</head>
<body>
<div></div>
<div></div>
<div></div>
<div></div>
</body>
</html>
从两个例子可以看出:对于多物体运动来说,不能使用公用的参数,可以通过添加属性来完成。
相关文章推荐
- js运动技术--多物体运动框架(变宽、变高、改变字体、改变border、透明度)以及替换offset的使用
- js完美多物体运动框架(缓冲运动)
- 点滴积累【JS】---JS小功能(JS实现多物体缓冲运动)
- JS运动之多物体框架--多个div变宽
- js封装多物体运动函数
- js中封装多物体运动及透明度变化函数
- JS多物体 任意值 链式 缓冲运动
- 学习js运动多个物体宽度变化笔记
- js运动-多物体运动
- js运动-改变透明度(单物体)
- (36)JS运动之使物体向右运动
- JS实现多物体缓冲运动实例代码
- (36)JS运动之使物体向右运动
- js多个物体运动问题2
- JS运动-放大缩小物体(从中心)
- JS实现多物体缓冲运动实例代码
- js多个物体运动的问题1
- js多物体任意值运动
- 原生js多动画同时运动框架(style属性多项同时改变)
- JS多物体运动