1
我正在使用mootools 1.4.1,我试图获得一个“补间”屏幕宽度以在完成时触发另一个函数的div。然而,补间继续射击,我不相信它是射击我想要的功能。使用mootools的代码1.4.1导致无限循环
的代码如下:
$('photo-loading_amt').set('tween', {duration: '1000ms',
link: 'cancel',
transition: 'linear',
property: 'width',
onComplete: function() {
var photoContainers = $$('.photo-container')
if (photoNum != photoContainers.length) {
nextPhoto(photoNum.toInt() + 1);
}
else {
nextPhoto(1);
}
}
});
,你可能有,将不胜感激任何帮助。
@Dimitar克里斯托夫,这里是为nextPhoto函数的代码:
function nextPhoto(photoNum) {
resetTimeline();
var photoContainers = new Array();
photoContainers = $$('.photo-container');
var photoFx = new Fx.Tween(photoContainers[photoNum.toInt() - 1], {
duration: 'normal',
transition: Fx.Transitions.Sine.easeOut,
property: 'opacity',
onComplete: function() {
photoContainers[photoNum.toInt() - 1].setStyle('visibility', 'hidden');
photoContainers[photoNum.toInt() - 1].setStyle('opacity', 1);
if (photoNum == photoContainers.length) {
photoContainers[0].setStyle('z-index', photoContainers.length);
}
}
});
if (photoNum == photoContainers.length) {
photoContainers[0].setStyle('z-index', 0);
}
photoFx.tween(1, 0);
//alert("photoNum = " + photoNum + "\n" + "photoContainers.length = " + photoContainers.length);
if (photoNum == photoContainers.length) {
photoContainers[0].setStyle('visibility', 'visible');
}
else {
photoContainers[photoNum.toInt()].setStyle('visibility', 'visible');
//loadingPhotos(photoNum.toInt() + 1);
}
// hard reset the loadingPhotos function
} //函数结束nextPhoto
这段代码确实没有显示任何递归,除非nextPhoto调用相同的代码,这会导致onComplete再次触发。请你再多展示一下。否则,你可以尝试使用onComplete的pseudo:once事件,例如。 'element.get(“tween”)。addEvent(“complete:once”,fn)' –
@Dimitar Christoff,这里是nextPhoto的代码。它_does_调用加载图片,上面的代码嵌入的功能,但它现在被注释掉了,它仍然重复。 – forgivenphoenix