【发布时间】:2013-07-20 17:19:15
【问题描述】:
我有成对的元素需要同时开始淡出/淡入。也就是说,一对中的两个元素应该只在淡出完成时才开始淡入;并在淡入完成后淡出。
我基本上在一对中的两个元素上使用$.when 来实现淡入和淡出。基本上,要等到褪色完成。它是否正确?有什么比这个解决方案更简单?
完整代码:jsFiddle
$.when($('.next-' + id).fadeOut(500)).done(function () {
var n = ...
$.when($('.next-' + n).fadeIn(500)).done(function () {
...
});
});
另外,.fadeOut() 返回一个 jQuery 对象。我们如何将它传递给 $.when,它需要一个 Deferred 对象?帮忙?
【问题讨论】:
-
感谢@ArunPJohny,但这并不能保证
.fadeIn()仅在.fadeOut()完成后才会发生。例如,尝试设置... fadeOut(50 * 1000).promise(), ... .fadeIn(0.8 * 1000).promise(), ...,即淡出真长,淡入真短。
标签: jquery jquery-animate jquery-deferred promise