Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/leafoftree/svelte-lazy
A svelte component to lazyload any content including images
https://github.com/leafoftree/svelte-lazy
lazy lazyload svelte
Last synced: 6 days ago
JSON representation
A svelte component to lazyload any content including images
- Host: GitHub
- URL: https://github.com/leafoftree/svelte-lazy
- Owner: leafOfTree
- License: unlicense
- Created: 2019-08-02T03:07:48.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2024-03-13T04:25:19.000Z (11 months ago)
- Last Synced: 2024-04-14T07:37:35.794Z (10 months ago)
- Topics: lazy, lazyload, svelte
- Language: Svelte
- Homepage:
- Size: 1.12 MB
- Stars: 136
- Watchers: 4
- Forks: 15
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# svelte-lazy [![npm version][3]][4]
A svelte component to lazyload any content.
- [Demo on svelte.dev/repl][5]
- [Examples][7] and [their code][8]
## Installation
npm i svelte-lazy
For sapper server-side rendering which requires [using external components][6], install it to `devDependencies`:
npm i -D svelte-lazy
## Usage
```html
import Lazy from 'svelte-lazy';
```
## Props
- **height**: *Number|String*. Default: `0` (px).
- Height of the component before load.
- **Set a proper value** to avoid scroll bounce. You can use the content height shown by the DevTools Inspector after loading.- **keep**: *Boolean*. Default: `false`.
- By default elements get unloaded after leaving view, set to `true` to keep all loaded ones after first appearance.- **offset**: *Number*. Default: `150` (px).
- Offset from the top of the component to the bottom of the viewport that triggers loading when in it.- **placeholder**: *String|Component*. Default: `null`.
- Placeholder before load.- **placeholderProps**: *Object*. Default `null`.
- Props for when using a component as a placeholder.- **class**: *String*. Default: `''`.
- Additional class for the container div. It will be `svelte-lazy ${class}`.- **fadeOption**: *Object*. Default: `{ delay: 0, duration: 400 }`.
- Option for the fade in transition. Set `null` to disable it.- **onload**: *Function (node) => {}*. Default: `null`.
- Function that is called when loaded.- **resetHeightDelay**: *Number*. Default: `0` (milliseconds).
- The delay to reset the component height to `auto` after loaded. Might be useful to wait for remote resources like images.## Changelog
v1.2.2
- Support svelte 3 & 4
- Load/unload when enters/leaves viewv0 -> v1.0
- Adjust dom structure
- Optimize image loading## Life cycle
```
enter viewport / no image -> loaded
not loaded -------------->
\ with image -> load event -> loaded
|
|
show placeholder | show content
```## DOM structure
Before load
```html
...
```After load
```html
...
```## Development
git clone https://github.com/leafOfTree/svelte-lazy
cd svelte-lazy
npm i
npm start## Test
npm test
## Publish
For maintenance, bump the version in `package.json` then run `npm publish`.
## Refs
Based on [sveltejs/component-template: A base for building shareable Svelte components](https://github.com/sveltejs/component-template)
[1]: https://travis-ci.com/leafOfTree/svelte-lazy.svg?branch=master
[2]: https://travis-ci.com/leafOfTree/svelte-lazy
[3]: https://img.shields.io/npm/v/svelte-lazy.svg
[4]: https://www.npmjs.com/package/svelte-lazy
[5]: https://svelte.dev/repl/6d7714fa3cce4909af6c6d187271e0a1
[6]: https://github.com/sveltejs/sapper-template#using-external-components
[7]: https://leafoftree.github.io/svelte-lazy/
[8]: https://github.com/leafOfTree/svelte-lazy/blob/master/test/index.svelte