How can I control how Nivoslider preloads images?

14,203

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
    }
   });
});
Share:
14,203
Bilal Ali Akbar
Author by

Bilal Ali Akbar

Updated on June 16, 2022

Comments

  • Bilal Ali Akbar
    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
    Bilal Ali Akbar over 12 years
    Thanks 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
    Bilal Ali Akbar about 12 years
    I'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
    Bilal Ali Akbar about 12 years
    Thanks 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
    Bilal Ali Akbar about 12 years
    Please read the question. Preloading is the problem, not the solution.
  • Bilal Ali Akbar
    Bilal Ali Akbar about 12 years
    Wow 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
    burak altundal about 12 years
    If 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
    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
    Bilal Ali Akbar about 12 years
    Got 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
    Akshay Hegde almost 6 years
    Github link is broken