我有以下jquery代码:
$('#swipe').on('click',function(){
$('.swipe-1').animate({width:'100%'},1000);
$('.swipe-2').delay(1000).animate({width:'100%'},1000);
$('.swipe-3').delay(2000).animate({width:'100%'},1000);
$('.swipe-4').delay(3000).animate({width:'100%'},1000);
$('.swipe-5').delay(4000).animate({width:'100%'},1000);
$('.swipe-6').delay(5000).animate({width:'100%'},1000);
$('.swipe-7').delay(6000).animate({width:'100%'},1000);
});我能缩短上面的代码吗?
发布于 2014-04-03 04:31:21
您可以使用像swipe这样的公共类,而不是创建7个不同的类:
$('#swipe').on('click',function(){
$('.swipe').each(function(i,v){
$(this).delay(i*1000).animate({width:'100%'},1000);
});
});延迟()在这里可能不起作用,因为没有动画的queue,所以setTimeout更好地使用
$('#swipe').on('click',function(){
$('.swipe').each(function(i,v){
var $this=$(this);
setTimeout(function(){
$this.animate({width:'100%'},1000);
},(i*1000));
});
});发布于 2014-04-03 04:22:17
像这样?
$('#swipe').on('click',function(){
for(var i=0;i<7;i++){
$('.swipe-'+(i+1)).delay(i*1000).animate({width:'100%'},1000);
}
});https://stackoverflow.com/questions/22827790
复制相似问题