lazyload-elements

2.0.4 • Public • Published

Lazyload Elements

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.

Historically, detecting visibility of an element, or the relative visibility of two elements in relation to each other, has been a difficult task for which solutions have been unreliable and prone to causing the browser and the sites the user is accessing to become sluggish

Usage

npm i lazyload-elements

import lazyLoadElements from "lazyload-elements";

window.addEventListener("load", function() {
  lazyLoadElements("iframe", "lazy-iframe", "src");
  lazyLoadElements("a", "lazy-href", "href");
  lazyLoadElements("img", "lazy-image", "src");
});

Important

data-src is required.

For iframe

<iframe loading="lazy" class="lazy-iframe" width="100%" height="425" src="" data-src="https://www.youtube.com/embed/ScMzIvxBSi4?rel=0?version=3&enablejsapi=1" frameborder="0" allowfullscreen></iframe>

lazyLoadElements("iframe", "lazy-iframe", "src");

For images

<img class="lazy-img" data-src="https://i.picsum.photos/id/645/200/300.jpg?hmac=fiKW3Nj8r0CWJQY3S-kkeT8PAfvKhA8igd9GIRk41Yw" src="" alt="Lorem">

lazyLoadElements("img", "lazy-img", "src");


Params

lazyLoadElements(target, targetClassName, attribute) {

target

Target element

targetClassName

Selector-Specific Class

attribute

Target element attribute

Target Attribute
a
img src
iframe src

Dependency

IntersectionObserver Polyfill

Readme

Keywords

none

Package Sidebar

Install

npm i lazyload-elements

Weekly Downloads

6

Version

2.0.4

License

ISC

Unpacked Size

11.2 kB

Total Files

11

Last publish

Collaborators

  • joci93