Vanilla JS Lazy Show Library
install via npm:
npm install ldlazy
include the required files:
<link rel="stylesheet" type="text/css" href="path-to-dist/index.min.css">
<script type="text/javascript" src="path-to-dist/index.min.js"></script>
construct a ldlazy object:
ldlz = new ldlazy({root: document.body, toggle: function(n) { ... } });
ldlz.add( ... );
root
- root element for monitoring scroll.toggle
- when visibility changes, toggle will be called with the target node as param. default null.debounce
- millisecond delay before handling events. require debounce.js, otherwise will be ignored.
ldlz.add(n)
- start monitoring node n for visibility change.ldlz.remove(n)
- stop monitoring node n for visibility change.
To make it easier to add an ldlazy image tag, we offer a pug mixin with a minimized gif placeholder, which can be used as:
include path-to-dist/index.pug
+ldlz("your-file")( ...attributes... )
An example with @plotdb/srcbuild
:
include @/ldlazy/dist/index.pug
+ldlz("thumbnail.png").custom-cls(width="800px",height="600px",alt="thumbnail")
which generates following html:
<img class="ldlz clustom-cls" src="" data-src="thumbnail.png" width="800px" height="600px" alt="thumbnail">
ldlazy controls the visibility of an element based on the event from IntersectionObserver. Two styles will be touched:
visibility
opacity
Alternatively, you can specify a source url for showing / lazy loading an image when the element becomes visible. Use src
or data-src
(for lazy loading ) attributes to indicate image url:
<div src=""></div>
<img data-src="...">
ldlazy fill the corresponding field ( style.backgroundImage
for div
, src
for img
) when the element is visible.
Additionally, specify following css class over an element for additional effect:
nocache
: always load this image with a randomized querystring, which forcily disable the cache.- useful for transitional animated SVG
placeholder
: insert a invisible placeholder image with given URL inside this node.- the image may be loaded before visible, so it becomes lazy show instead of lazy load.
- only applicable for container type node ( such as div ).
init()
: askldlazy
to scan and init all elements withldlz
classes.
When using with img
tag, you may want to fill following attributes to prevent CLS - Cumulative Layout Shift:
-
width
andheight
: set to the expected size of your image.- this will be overwritten if you also specify values in stylesheet, but it helps in keeping aspect ratio.
-
src
: you can still fillsrc
attribute with a 66 bytes long, single pixel, transprent gif:
- this is available as a mixin named
ldlz
in Pug after includingdist/index.pug
, withsrc
as only parameter:
+ldlz("path-to-your-image")(additional-attribute="here", ...)
Placeholder image prefilled in src
attribute can prevent a broken image or alt
attribute to be shown. While we may prefer transparent placeholder image, ldlazy actually make elements transparent before revealing them so we actually don't need a real transpareny pixels.
Here are some possible smallest images, with their corresponding sources:
smallest 1px gif (26bytes/58bytes, currently used), may be shown as black in some browsers (e.g., IE11):

smallest transparent 1px gif (33bytes/66bytes):

alternative with SVG (41bytes/60bytes)
data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg"/>
check following pages for more resources about a minimal image:
- 26 bytes one:
- 33 bytes one:
MIT