1

我正在使用 mootools 1.4.1 并且我正在尝试获取一个 div 来“补间”屏幕宽度以在完成时触发另一个功能。但是,补间一直在触发,我不相信它会触发我想要的功能。

代码如下:

$('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 Christoff,这是 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

4

1 回答 1

0

由于我在您的代码中没有看到明显的循环,因此我怀疑这种影响是由

link: 'cancel'

在您的第一个代码块中。根据 Moo 文档,这将:

'cancel' - 在效果运行时对 start 的任何调用都将优先于当前运行的转换。新的过渡将立即开始,取消当前正在运行的过渡。

所以这可能会让你的青少年感到不安。但是,您可能是故意添加的。我会尝试在您的第一个和第二个补间设置中将其更改为chainor ignore,以查看最佳组合。如果这不能解决它,也许您可​​以发布更多代码。例如,我看不到该resetTimeline函数的代码。也许您的代码卡在这里。

于 2011-10-28T07:53:43.717 回答