0
我通过动画列表运行,像这样:队列动画。每个功能
function katz_logo() {
$('#logo')
.delay(500)
.animate({opacity: 1}, 1000)
.queue(katz_subsites);
}
function katz_subsites() {
var subsites = $('#subsites li'),
subsitesLength = subsites.length;
subsites.each(function(i) {
$(this)
.delay(i * 300)
.animate({top:0, opacity: 1 }, 800);
if (i === subsitesLength - 1) {
alert('hi');
}
});
}
function katz_video() {
if (!Modernizr.touch) {
$('#home_video').delay(500).fadeIn(1000);
}
}
katz_logo();
每个动画被定义为一个函数,然后最终与katz_logo()
调用来启动的魔力。在katz_subsites()
函数中,我遍历每个可用的li
,然后我要做的是在达到最后一个元素后排队katz_video()
函数,但即使我的警报实验没有按预期工作。
所以 - 我遇到麻烦的部分是如何获取最后一个值(我发誓我一直在遵循这里的其他答案),然后如何在达到该值后对队列进行排队。
任何帮助将不胜感激。谢谢!
更新
的代码进展 - 仍然停留在在each()
声明针对的是最后一个元素,然后排队下一个动画:
function katz_logo() {
$('#logo')
.delay(500)
.animate({opacity: 1}, 1000, katz_subsites);
}
function katz_subsites() {
var subsites = $('#subsites li'),
subsitesLength = subsites.length;
subsites.each(function(i) {
$(this)
.delay(i * 300)
.animate({top:0, opacity: 1 }, 800);
if (i === subsitesLength - 1) {
i.queue(katz_video);
}
});
}
function katz_video() {
if (!Modernizr.touch) {
$('#home_video').delay(500).fadeIn(1000);
}
}
katz_logo();
工作代码:
function katz_logo() {
$('#logo')
.delay(500)
.animate({opacity: 1}, 1000, katz_subsites);
}
function katz_subsites() {
var subsites = $('#subsites li'),
subsitesLength = subsites.length;
subsites.each(function(i) {
$(this)
.delay(i * 300)
.animate({top:0, opacity: 1 }, 800, (i===subsitesLength-1 ? katz_video : (function(){})));
});
}
function katz_video() {
if (!Modernizr.touch) {
$('#home_video').delay(500).fadeIn(1000);
}
}
katz_logo();
啊很漂亮,让'queue'联合国需要的那部分。欣赏这一点。那么我唯一缺少的部分就是定位'each()'函数中的最后一个元素。我认为我可以在这方面申请'i.queue(katz_video)'(一旦我正确定位),但任何帮助都会很好。再次感谢! – Zach
@Zach我不是100%的脚本,但我已经更新了我的答案。 – Emissary
嗨@使者 - 哟,更清洁 - 奇怪的是,如果我甚至把这种检查的两种情况都改成'alert'('hi')'我什么也没得到。 – Zach