为什么这不正常?我试图实现的效果是块从左向右移动,并开始“推动”下一个。嵌套回调在外部元素上执行动画似乎是一个问题。
任何人都能解释一下吗?它有点可行,但一切都动了很多次。
<html>
<head>
<style>
.item { width: 49px; height: 49px; border: 1px solid orange; background-color: #ccccff; }
#i0 { position: absolute; left: 0px; }
#i1 { position: absolute; left: 150px; }
#i2 { position: absolute; left: 200px; }
#i3 { position: absolute; left: 250px; }
#i4 { position: absolute; left: 400px; }
#i5 { position: absolute; left: 450px; }
</style>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.3.2/jquery.min.js"></script>
<script>
jQuery(function() {
$("#i0").animate({left:"+=100"}, function() {
$("#i0,#i1,#i2,#i3").animate({left:"+=100"}, function() {
$("#i0,#i1,#i2,#i3,#i4,#i5").animate({left:"+=50"});
});
});
});
</script>
</head>
<body>
<div id="i0" class="item"></div>
<div id="i1" class="item"></div>
<div id="i2" class="item"></div>
<div id="i3" class="item"></div>
<div id="i4" class="item"></div>
<div id="i5" class="item"></div>
</body>
</html>
答案 0 :(得分:3)
animate()的第二个参数是动画完成时调用的回调。由于$(“#i0,#i1,#i2,#i3”)。animate(..)动画4件事,它会调用4次回调。这样的方法可能有效:
function move(i, left, callback) {
$("#i"+i).animate({left:left}, callback);
}
function sequence(n, left, callback) {
return function() {
var i = 0;
for (; i < n; i++) {
move(i, left);
}
move(i, left, callback);
}
}
jQuery(function() { move(0, "+=100", sequence(3, "+=100", sequence(5, "+=100"))) });