Search code examples
javascriptjqueryhtmldomimage-loading

Change loading order of images already on page


Is there any way without AJAX of changing the loading order of images on a page? Or even a way to completely halt or pause loading of images already present?

The use case is simple - I have a long list of images down a page, and visitors will be landing on different spots of the page using URL anchors (/images#middle-of-page) that refer to actual containers for those images.

I'd like in the least to load the images inside the requested container FIRST, then continue loading the rest of the images.

The challenge is that there is no way to know the image paths of the requested container image before loading the page DOM.

I've tried getting the container img contents on load, then using the Javascript new Image() technique, but it doesn't change the fact that that image on the page will still be waiting for all previous images to load.

I've also tried immediately prepending a div in the body with a background image (CSS) of said img path, but this also does not prioritize the image load.

Any other ideas?


Solution

  • You need to have a DOM with empty img placeholders, i.e.

    <img src="" mysrc="[real image url here]" />
    

    Or you can make images to display "Loading..." image by default. You can even cache real image url in some custom tag, mysrc for example. Then once you know what exactly images you want to show (and in what order) you need to build a sequence of image loading

    var images = [];//array of images to show from start and in proper order
    function step(i){
      var img = images[i++];
      img.onload = function(){
        step(i);
      }
      img.src = "[some url here]"
    }
    

    Hope this helps.