lazy-image-renderer
TypeScript icon, indicating that this package has built-in type declarations

1.1.8 • Public • Published

lazy-image-renderer 🎨

Version License

Description

A React component that optimizes image loading using Intersection Observer, providing smooth transitions and improved performance for lazy image rendering.

lazy-loading

Get started

npm install lazy-image-renderer --save

or

yarn add lazy-image-renderer

Use

import { LazyImageRenderer } from 'lazy-image-renderer';

Examples

Default

<LazyImageRenderer src='http://jnisperuza-images.infinityfreeapp.com/vangogh-lg.jpg' />

Responsive image source

<LazyImageRenderer
  sizes='(max-width: 600px) 120px, (max-width: 900px) 193px, 278px'
  src='http://jnisperuza-images.infinityfreeapp.com/vangogh-lg.jpg'
  srcSet='http://jnisperuza-images.infinityfreeapp.com/vangogh-sm.jpg 120w, http://jnisperuza-images.infinityfreeapp.com/vangogh.jpg 193w, http://jnisperuza-images.infinityfreeapp.com/vangogh-lg.jpg 278w'
/>

Effects

Blur

<LazyImageRenderer
  effect='blur'
  effectDuration={0.5}
  objectFit='cover'
  src='http://jnisperuza-images.infinityfreeapp.com/vangogh-lg.jpg'
/>

blur-effect

Black and white

<LazyImageRenderer
  effect='black-and-white'
  objectFit='cover'
  src='http://jnisperuza-images.infinityfreeapp.com/vangogh-lg.jpg'
/>

black-and-white-effect

Opacity

<LazyImageRenderer
  effect='opacity'
  objectFit='cover'
  src='http://jnisperuza-images.infinityfreeapp.com/vangogh-lg.jpg'
/>

Effect Duration

The duration will be read in seconds from a number, for instance: 1 = 1 second, 0.5 = 500 milliseconds.

<LazyImageRenderer
  effect='opacity'
  effectDuration={0.4}
  objectFit='cover'
  src='http://jnisperuza-images.infinityfreeapp.com/vangogh-lg.jpg'
/>

Intersection Options

<LazyImageRenderer
  effect='opacity'
  objectFit='cover'
  src='http://jnisperuza-images.infinityfreeapp.com/vangogh-lg.jpg'
  intersectionOptions={{
    rootMargin: '100px',
    threshold: 0.15,
  }}
/>

ezgif com-gif-maker

Properties

src is the only required property, all other properties are optional.

Property type Description
name string Specifies a name for a wrapper component.
className string Specifies a custom class for a wrapper component, is possible to send multiple class separate with spaces ("foo baz").
alt string Specifies an alternate text for an image.
crossorigin anonymous, use-credentials Allow images from third-party sites that allow cross-origin access to be used with canvas.
longdesc string Specifies a URL to a detailed description of an image.
objectFit fill, contain, cover, scale-down, none Property is used to specify how an img or video should be resized to fit its container.
referrerpolicy no-referrer, no-referrer-when-downgrade, origin, origin-when-cross-origin, unsafe-url Specifies which referrer information to use when fetching an image.
ismap boolean When present, it specifies that the image is part of a server-side image map (an image map is an image with clickable areas).
usemap string Specifies an image as a client-side image map.
src string [required] Specifies the path to the image.
sizes string Specifies image sizes for different page layouts.
srcSet string[] Specifies a list of image files to use in different situations.
height number, string Specifies the height of an image, *If it is not sent, the value of the parent is taken.
width number, string Specifies the width of an image, *If it is not sent, the value of the parent is taken.
effect blur, black-and-white, opacity Specifies the transition of how the image appears. It has a time of 8 milliseconds.
effectDuration number Specifies the transition time (expressed in seconds) of the image appearance.
intersectionOptions IntersectionOptions The IntersectionObserver interface of 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.
draggable boolean When set to true, the draggable attribute allows users to click and drag the associated element using their mouse or touch input, providing an interactive and user-friendly interface for elements.

Read more: #dom-intersectionobserver

interface IntersectionOptions {
  root?: Element | null;
  rootMargin?: string;
  threshold?: number | number[];
}

Live example

https://stackblitz.com/edit/lazy-image-renderer?file=App.tsx

Author ✒️

Readme

Keywords

none

Package Sidebar

Install

npm i lazy-image-renderer

Weekly Downloads

3

Version

1.1.8

License

ISC

Unpacked Size

42.3 kB

Total Files

11

Last publish

Collaborators

  • jnisperuza