How can I control how Nivoslider preloads images?
Solution 1
I've been looking for a similar solution. I have an image gallery on a web site that loads a dozen high-quality images on the home page using a slideshow plugin. And all these images are being loaded at once adding 2-3 megs to the page weight. No dice.
Nivo leaves image handling up to the browser. It reads the <img src="...">
tag and then gussies up the images into a slideshow with slick transition effects. There's nothing in code to control the loading or preloading of images.
Fortunately Nivo is on Github. So I forked it to support lazy loading of images:
https://github.com/leepowers/Nivo-Slider
The usage is the same. With one small change to the HTML
<div id="slider">
<img src="my-large-image.jpg" alt="">
<img src="my-large-image2.jpg" alt="">
<img src="another-biggun.jpg" alt="">
</div>
Change the image src
attributes to data-src
attributes:
<div id="slider">
<img data-src="my-large-image.jpg" alt="">
<img data-src="my-large-image2.jpg" alt="">
<img data-src="another-biggun.jpg" alt="">
</div>
Since data-src
is not parsed the images aren't loaded until Nivo is ready to use them. data-src
has precedence over src
which means you can specify low-res versions in src
for non-javascript users, or populate src
with a spacer image so the HTML will pass a validator.
Check it out! I'm implementing it on several projects. A demo is available here: http://powers1.net/files/nivo/demo/demo-lazy.html
Solution 2
Nivo slider does not have an image preloader. If you are using your slider with jQuery load event(as in demos of nivo), nivo slider will wait until all images loaded in page.
$(window).load(function() {
$('#slider').nivoSlider();
});
If you do not want to wait until all images loaded you might prefer document ready event as below. No images will be preloaded.
$(document).ready(function() {
$('#slider').nivoSlider();
});
If you want to have a controlled preloading; You may use one of image preload plugins of jQuery like; http://www.farinspace.com/jquery-image-preload-plugin/
$(document).ready(function() {
$('#slider').nivoSlider();
//Before starting the slider preload your images then start your slider.
$.imgpreload(['/images/a.gif','/images/b.gif'],
{
all: function()
{
//Start slider here
}
});
});
Bilal Ali Akbar
Updated on June 16, 2022Comments
-
Bilal Ali Akbar almost 2 years
I'm using the excellent Nivoslider plugin to showcase a set of photos on my homepage, currently 5. All is working fine, but each photo adds about 150K to the page weight. I would actually want to showcase about 10 "slides", but since all these images are preloaded at the opening of the page, the page weight will soon become (too) large, especially since many users will likely not wait for the "show" to finish.
I was wondering if it is possible to not preload images, or beter, only x images ahead. I can't find anything about it in the documentation, so I presume it is not natively supported. Any ideas?
-
Bilal Ali Akbar over 12 yearsThanks for the answer, but this does not solve the original problem. This suggestion will delay the loading of the slider as a whole, whilst what I want is for the slider to load yet the images to be lazy loaded.
-
Bilal Ali Akbar about 12 yearsI'm sorry, but the question is not to preload images. Preloading is the problem, not the solution. In this case they should be lazy loaded.
-
Bilal Ali Akbar about 12 yearsThanks for thinking along, looks like a creative idea. Having said that, I am increasingly thinking that I should simply switch to another plugin if it requires this amount of tinkering :)
-
Bilal Ali Akbar about 12 yearsPlease read the question. Preloading is the problem, not the solution.
-
Bilal Ali Akbar about 12 yearsWow that looks so promising, thanks! I'm going to testdrive this in the coming days, I'll get back to you with the results.
-
burak altundal about 12 yearsIf you use document ready event preloading is optional, you can just directly start the slider. In that case no images will be preloaded. My example shows, if you want to use preloader with your own limits, you can. I will update the example.
-
trickyzter about 12 years@Ferdy The idea is simple enough, if you would like me to produce a sample based on your own code, I wouldn't mind.
-
Bilal Ali Akbar about 12 yearsGot it working on dev, I'll grant you the correct answer and will credit you on my blog once I go live with this part. Once again, awesome work!
-
Akshay Hegde almost 6 yearsGithub link is broken