throttle-lazy-load
v1.0.2
Published
Simple & light weight (<3kb gzipped) vanilla javascript plugin to lazy load.
Downloads
5
Maintainers
Readme
lazy-load
Simple & light weight (<3kb gzipped) vanilla javascript plugin to lazy load.
DEMO
Getting Started
NPM Setup
npm install throttle-lazy-load
import Lazy from 'throttle-lazy-load/lib/Lazy.js'
Basic Browser Setup
- Add lazy to your html
<script src='./lib/Lazy.js'>
- Initialize the plugin
Lazy.create().start({})
- add attribute to the HTML tags you want to lazy-load
<img lazy-img='xxx.jpg'>
- lazy load
custom
interval
You can pass options into your custom lazy load.
Lazy.create().lift({fn: () => new time, num: 300}).start({})
This can make your lazy load throttle 300s.
extend
Lazy.create({extend: 200})
This can make your lazy load extend 200px.
attribute
Lazy.create({attr: 'data-img'})
This can make your lazy load attribute for 'data-img
el && event
Lazy.create().start({el: button, event: 'click'})
This can make your lazy load for bottom addEventListener click
release memory
removeEventListener
when start listen, you can execute this to removeEventListener
const lazy = Lazy.create().start({el: button, event: 'click'})
lazy() // removeEventListener
destory
const lazy = Lazy.create()
lazy.destory() // destory remove elements/listeners/interval
ToDo
- demo
- Intersection Observer API design
- code cleanup
- typescript support