我一直在努力尝试实施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>
答案 0 :(得分:0)
尝试打印imageArray[i]
和imageItem(imageDir + i + ".jpg")
,看看它是否符合您的期望。我相信这是解决方案的关键...... :)