Is there a way to control the load order of images on a web page? I was thinking of trying to simulate a preloader by first loading a light-weight 'LOADING' graphic. Any ideas?
Thanks
You can provide a priority hint using the fetchpriority HTML attribute. You can use the attribute with link , img , script , and iframe tags. The attribute allows you to specify the priority for resource types such as CSS, fonts, scripts, images, and iframe when downloaded using the supported tags.
The image is considered completely loaded if any of the following are true: Neither the src nor the srcset attribute is specified. The srcset attribute is absent and the src attribute, while specified, is the empty string ( "" ). The image resource has been fully fetched and has been queued for rendering/compositing.
Use Javascript, and populate the image src
properties later. The #
tells the browser to link to a URL on the page, so no request will be sent to the server. (If the src
property was empty, a request is still made to the server - not great.)
Assemble an array of image addresses, and recurse through it, loading your images and calling a recursive function when the onload
or onerror
method for each image returns a value.
HTML:
<img src='#' id='img0' alt='[]' /> <img src='#' id='img1' alt='[]' /> <img src='#' id='img2' alt='[]' />
JS:
var imgAddresses = ['img1.png','img2.jpg','img3.gif']; function loadImage(counter) { // Break out if no more images if (counter==imgAddresses.length) { return; } // Grab an image obj var I = document.getElementById("img"+counter); // Monitor load or error events, moving on to next image in either case I.onload = I.onerror = function() { loadImage(counter+1); } //Change source (then wait for event) I.src = imgAddresses[counter]; } loadImage(0);
You could even play around with a document.getElementsByTagName("IMG")
.
By the way, if you need a loading image, this is a good place to start.
EDIT
To avoid multiple requests to the server, you could use almost the same method, only don't insert image elements until you're ready to load them. Have a <span>
container waiting for each image. Then, loop through, get the span object, and dynamically insert the image tag:
var img = document.createElement("IMG"); document.getElementById('mySpan').appendChild(img); img.src = ...
Then the image request is made only once, when the element is created.
I think this article https://varvy.com/pagespeed/defer-images.html gives a very good and simple solution. Notice the part which explains how to create "empty" <img> tags with:
<img src="" data-src="your-image-here">
to avoid <img src="">
To display a loading image, just put it in the HTML and change it later at the appropriate moment/event.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With