Deferring images without lazy loading or jQuery


HTML • JavaScript

Place this function either in your page header or shared JS file for reference on multiple pages. It will loop through all images that have a "data-src" attribute and use that value to replace the img object's SRC value.

<script>
function imgOnloadDefer() {
	var imgDefer = document.getElementsByTagName('img');
	for (var i=0; i<imgDefer.length; i++) {
		if(imgDefer[i].getAttribute('data-src')) {
			imgDefer[i].setAttribute('src',imgDefer[i].getAttribute('data-src'));
		}
	}
}
window.onload = imgOnloadDefer();
</script>

Structure your image HTML tag(s) with a blank image URL listed as the src or you can use a base64 image. Place the actual image SRC in the attribute data-src.

<!-- USING A BASE64 image as the default (this example below will be a 1px black dot) -->
<img src="" data-src="YourImageHere1.jpg" alt="image 1">
<img src="" data-src="YourImageHere2.jpg" alt="image 2">


<!-- Using a blank 1px image like spacer.gif  -->
<img src="spacer.gif" data-src="YourImageHere1.jpg" alt="image 1">
<img src="spacer.gif" data-src="YourImageHere2.jpg" alt="image 2">

Written by Patrick Sexton https://www.feedthebot.com/pagespeed/defer-images.html

Posted by fbrefere001 on Thursday August 25, 2016