A super simple lazy render script for whatever element(s) you want.
dist/
├── lazy-render.js
└── lazy-render.min.js
# npm
npm i @astrocaleb/lazy-render
In browser:
<script src="/path/to/lazy-render.js"></script>
<... data-lazy-render="<attribute>;<value>" ...>
new LazyRender([options])
- options (optional)
- Type:
Object
- The options for rendering. Check out the available options.
- Type:
<img data-lazy-render="src;picture-1.jpg">
<img data-lazy-render="src;picture-1.jpg">
<img data-lazy-render="src;picture-2.jpg">
<img data-lazy-render="src;picture-3.jpg">
import LazyRender from '@astrocaleb/lazy-render';
// Delay rendering of elements, all default values
new LazyRender();
// or
// Delay rendering, passing in options
new LazyRender({
threshold: 75,
callback: function() {
alert("I rendered!");
}
});
You can set LazyRender options with new LazyRender(options)
.
- Type:
Number
- Default:
50
Adjust when elements load, relative to the viewport. Threshold is a percentage of the viewport height and width, similar to the CSS vh
or vw
unit.
- Type:
Function
- Default: no-op
Callback that fires immediately after the element is set to render.
MIT