2

我正在使用 Jquery 在页面滚动时更改图像的来源。但是,目前它们正在显示时加载,我想让它们在显示之前预加载几张图像。

HTML

<img src="/img/1.jpg" />

jQuery

$(window).load(function(){
// Array of images to swap between
var images = [/img/1.jpg, /img/2.jpg, /img/3.jpg, /img/4.jpg];

var totalImages = images.length; 

var documentHeight = $(document).height();

// Work out how often we should change image (i.e. how far we scroll between changes)
var scrollInterval = Math.floor(documentHeight / totalImages);

$(document).scroll(function () {
// Which one should we show at this scroll point?
i = Math.floor($(this).scrollTop() / scrollInterval);
// Show the corresponding image from the array
$('img').attr('src', images[i]);
});
});//]]>  

css

img {
position: fixed;
top: 0;
left: 0;
height: 100%;
}
body {
height: 5000px;
}

试图。我想添加与此类似的内容,

$(document).scroll(function () {    
    function preload(arrayOfImages) {
        $(arrayOfImages).each(function(){
            (new Image()).src = this;
        });
    }

    i = Math.floor([i]+'1');

    preload([[i]]);
}

但无法弄清楚如何编码......(JS新手)

4

1 回答 1

0

在你的循环里面。

var nextTenImages = images.slice(i, i+10);    
// preload the next image
preload(nextTenImages);

JSFiddle:http: //jsfiddle.net/gvee/ygkWH/8/

编辑:归功于以下用于预加载图像的 SO 主题:使用 jQuery预加载图像

于 2013-08-06T14:32:23.800 回答