glicer/lazyload-img

lazy loading images

dev-master 2016-10-02 11:59 UTC

This package is not auto-updated.

Last update: 2024-11-09 20:22:59 UTC


README

Scrutinizer Code Quality Build Status Coverage Status SensioLabsInsight Dependency Status

Autoset html tags/attributes to lazy loading lossless/lossy images (gif, png, jpeg)

Server side with PHP

Using a blank image and set width/height

  • Add 1x1 gif blank image in data:uri attribute to all tags in html
  • Set width and height attributes with original image size (Browser is going to rescale automatically with width/height attribute)
$html = '<!DOCTYPE html><html><head></head><body><div><img src="img/test1.jpg"></div></body></html>';

$lazyload = new GlLazyLoadImg(__DIR__); //root directory parameter for relative url

$result = $lazyload->autoDataURI($html);

$result contain :

<!DOCTYPE html>
<html>
    <head>
    </head>
    <body>
        <div>
            <img src="" data-original="img/test1.jpg">
        </div>
    </body>
</html>

Using a lossy image and set width/height

  • Add reduced gif image in data:uri attribute to all tags in html
  • Set width and height attributes with original image size (Browser is going to rescale automatically with width/height attribute)
$html = '<!DOCTYPE html><html><head></head><body><div><img src="img/test1.jpg"></div></body></html>';

$lazyload = new GlLazyLoadImg(__DIR__,GlLazyLoadImg::LOSSY); //root directory parameter for relative url

$result = $lazyload->autoDataURI($html);

$result contain :

<!DOCTYPE html>
<html>
    <head>
    </head>
    <body>
        <div>
            <img src="" width="256" height="256" data-original="img/test1.jpg">
        </div>
    </body>
</html>

Client side with javascript

By example, you can use LazyLoad (aka Vanilla LazyLoad)