我有一個循環不會使用Prototype + Scriptaculous運行。它爲我的數組中的第一個對象運行一次然後停止。PrototypeJS循環將不會運行
var myMessages = new Object();
myMessages = ['success','info','warning','error']; // define the messages types
function hideAllMessages()
{
var messagesHeights = new Array(); // this array will store height for each
enter code here
// This one runs just once for the first item in the array
var i = 0;
myMessages.each(function(element) {
alert(element);
messagesHeights[i] = $('.' + element).getHeight();
i++;
$$('.' + element + ' message').invoke('hide');
});
//This won't run at all===============================
for (var index = 0; index < myMessages.length; index++)
{
messagesHeights[index] = $('.' + myMessages[index]).getHeight();
$('x').hide();
//$('.' + myMessages[i]).css('top', -messagesHeights[i]); //move element outside viewport
}
}
看看你的瀏覽器的控制檯。有什麼錯誤信息?我敢打賭,你有一個分配給數組'messagesHeights'的問題,它還沒有長度。 – clockworkgeek
@clockworkgeek - 你說得對,他可能有錯誤信息,但最有可能的是'$('。'+ element)'返回null。允許以這種方式分配給數組。 –
你說得很對。 'element.getHeight()'就足夠了。整個片段還有更多問題,將高度保持爲陣列沒有意義。 – clockworkgeek