imageArray [i] = imageItem不兼容

时间:2012-09-08 11:08:04

标签: javascript

我一直在努力尝试实施TheNoble-Coder对Difficulty in Understanding Slideshow script的回答。 对于包含不同数量图像的文件夹,他的“好吧,如果你想...”解决方案听起来像是一个非常优雅的解决方案。 但是我无法让它发挥作用。使用Yaldex的免费JavaScript编辑器进行调试我得到了指示行的“错误:不兼容类型”:

var place; //For convenience this is best as a global
function imageItem(url) 
{
    var img = new Image();
    img.src = url;
    return url;
}
for(var i=0; i<5; i++)
{
    imageArray[i] = imageItem(imageDir + i + ".jpg");   <-----Incompatible 
}

我真的很感激任何帮助。

整个脚本是:

     <script language="JavaScript">
var interval = 4000;
var random_display = 0;
var imageDir = "images/";
var imageNum = - 1;
var place; //For convenience this is best as a global
function imageItem(url) 
{
    var img = new Image();
    img.src = url;
    return url;
}
for(var i=0; i<5; i++)
{
    imageArray[i] = imageItem(imageDir + i + ".jpg");
}
function randNum(x, y)
{
   var range = y - x + 1;
   return Math.floor(Math.random() * range) + x;
}
function getNextImage() 
{
    imageNum = (random_display) ? randNum(0, imageArray.length-1) : ((imageNum+1) % imageArray.length);
    return imageArray[imageNum];
}
function getPrevImage()
{
    imageNum = (imageNum-1 >= 0) ? (imageNum-1) : (imageArray.length-1);
    return imageArray[imageNum];
}
function prevImage() 
{
    var image_item = getPrevImage();
    place.src = place.alt = image_item.url;
}
function nextImage() 
{
    var image_item = getNextImage();
    place.src = place.alt = image_item.url;
}
function play() 
{
    nextImage();
    timerID = setTimeout(play, interval);
}
window.onload = function()
{
    place = document.slideImg;
    play();
};

  </script>

1 个答案:

答案 0 :(得分:0)

尝试打印imageArray[i]imageItem(imageDir + i + ".jpg"),看看它是否符合您的期望。我相信这是解决方案的关键...... :)