Yall is a small javascript library (2.47KB) that uses intersection observer to lazy load images (or start events on class added) and with the option to use a callback function on every intersection.
From the mdn documentation: "The Intersection Observer API provides a way to asynchronously observe changes in the intersection of a target element with an ancestor element or with a top-level document's viewport.", currently from the information from caniuse, it has a global support of 87.85% and all modern web browsers now support it.
Lazy loading images is a best practice to request the assets only when they are indeed to be used, google developers talk about it.
No, in that case it will load all images like lazyload is not present (use the minfied version that is transpilled using babeljs).
At this moment there is no browser supporting it out of the box, but it also checks for that and make everything ready for it, but if you have other effects based on class change and callbacks you will need to refactor this.
Since everytime an element is "intersected" a class is added you can use css animations or use a callback function that will receive the element being intersected.
You just need to load yall.js and create an instance and make it run - run again if you change the DOM. Elements just need the class "yall_lazy" - you can define your classname, and images need to not have src/srcset and have instead data-src/data-srcset attributes.
When an element is intersected the default class yall_loaded is added and the callback function is called.
<script src="yall.min.js"></script> <script> var lazyload = new yall(); window.addEventListener('DOMContentLoaded', (e) => { lazyload.run(); }); </script> <img class="yall_lazy" data-src="link-to-image"> <div class="yall_lazy">Text that will translate when the class yall_loaded is added.</div>
A quick example with a callback function that will put output to the browser console the element src after it has been intersected:
<script> var lazyload = new yall({callback:"log"}); function log(a){ console.log(`loaded image with src= ${a.src}.`); } window.addEventListener('DOMContentLoaded', (e) => { lazyload.run(); }); </script>
The only method available after a instance is created is the .run() method that scans elements with the "yall_lazy" class that have not yet the class "yall_loaded".
The options available when you create an instance are:
let options = { //elems to search target : "classname", defaults to "yall_lazy" //class to add after being loaded classToLoad : "classname after intersect", defaults to "yall_loaded"; //intersectObserver threshold threshold : [0,1], defaults to 0; //root root : element, defaults to null; //rootMargin rootMargin : intersectObserver rootMargin, defaults to "0px 0px 600px 0px"; //callback callback : "function", defaults to null; //activate to ignore the attribute loading="lazy" in supported browsers useLoading : bool, defaults to false; }
Short answer: sure it can. Long answer: I just made this into a library because I only needed a quick working solution with a minimal of options, you can make a pull request or just ask, otherwise you have other options available for a more robust approach.
Just and image lazy loaded
Just and image lazy loaded
img.slowloading.yall_lazy { opacity: 0; transition: all 4s ease-in-out; } img.slowloading.yall_loaded { opacity: 1; }
Translating the element
.card.yall_lazy { transition: all 3s ease-in-out; transform: translateX(-50vw); opacity: 0; } .card.yall_loaded { transform: translateX(0px); opacity: 1; } }
rootMargin like rootMargin:"0px 0px -100px 500px"" to allow offscreen (left) elements
Just check the console :)
Just and image lazy loaded