maxisam / ngx-progressive-image-loader

lazy load img/picture, prevent reflow and seo friendly.
MIT License
35 stars 6 forks source link
angular image-lazy-load lazyload lazyload-images progressive-image

Build Status npm GitHub release [npm]()

ngx-progressive-image-loader

Support Angular >=6.0.0

Demo

stackblitz.com

Features

Install

npm install ngx-progressive-image-loader --save

Open your module file e.g app.module.ts and update imports array

import { NgxProgressiveImageLoaderModule, IImageLoaderOptions } from 'ngx-progressive-image-loader';
...
imports: [
...
     NgxProgressiveImageLoaderModule.forRoot(<IImageLoaderOptions>{
      // rootMargin must be specified in pixels or percent
      rootMargin: '30px',
      threshold: 0.1,
      // css filter
      filter: 'blur(3px) drop-shadow(0 0 0.75rem crimson)',
      // image width / height ratio for image holder
      imageRatio: 16 / 9,
      // loading image in placeholder. Can be URL or base64
      placeholderImageSrc:
        // tslint:disable-next-line:max-line-length
        ''
    })
...
]

Add style to your global scss

@import '~ngx-progressive-image-loader/ngx-progressive-image-loader';

$scale: 0.5; // the scale of loading image in place holder
$transition: opacity 1s linear; // the transition of loading image in place holder, you could try: opacity .3s ease
@include progressive-image-loader($scale, $transition);

Usage

<ngx-progressive-image-loader>
  <ngx-image-placeholder>
    <!-- ngx-image-placeholder is optional -->
    <img [src]="'/assets/Avengers1.jpg'" alt="" ngxProgressiveImage />
  </ngx-image-placeholder>
  <img src="https://github.com/maxisam/ngx-progressive-image-loader/raw/master/assets/Avengers2.jpg" alt="" ngxProgressiveImage />
</ngx-progressive-image-loader>
<ngx-progressive-image-loader>
  <img
    [src]="'/assets/Avengers6.jpg'"
    [srcset]="'/assets/Avengers6.jpg 800w,/assets/Avengers7.jpg 1366w'"
    size="(max-width: 1000px) 100vw, 100vw"
    ngxProgressiveImage
  />
</ngx-progressive-image-loader>
<ngx-progressive-image-loader>
  <picture ngxProgressiveImage>
    <source [srcset]="'/assets/Avengers4.jpg'" media="(max-width: 1000px)" />
    <source [srcset]="'/assets/Avengers5.jpg'" media="(min-width: 1000px)" />
    <img [src]="'/assets/Avengers4.jpg'" alt="My default image" />
  </picture>
</ngx-progressive-image-loader>

Configuration for IImageLoaderOptions

Intersection_observer_options

For ngx-image-placeholder component, it takes

(after 3.0.0, you can set imageRatio and placeholderImageSrc directly on ngxProgressiveImage and spare ngx-image-placeholder layer)

For ngx-progressive-image-loader component, it takes

For ngxProgressiveImage directive, (only for image or source elements)

Build project

npm i

npm run build

To run demo code locally

npm run start

Browser Compatibility

Browsers don't support Intersection Observer API will not work as expect. It will load images like old time.

Use pollyfill like below might make it work.

<script src="https://polyfill.io/v2/polyfill.min.js?features=IntersectionObserver"></script>

Contributing

Troubleshooting

Please ask your general questions at https://stackoverflow.com

Shoutouts 🙏

This project was generated with Angular CLI version 6.2.0 beta 02.

Kudos to the following authors:

https://deanhume.com/lazy-loading-images-using-intersection-observer/

https://www.voorhoede.nl/en/blog/say-no-to-image-reflow/

https://jmperezperez.com/medium-image-progressive-loading-placeholder/

https://github.com/verlok/lazyload for detecting spider

And my wife and my child to let me work on a weekend for this.

BrowserStack Logo

Big thanks to BrowserStack for letting the maintainers use their service to debug browser issues.