Search code examples
javascriptphphtmlcsszend-framework

how to make a blurry lazy image loading for your website?


I have a website full with images and the web site performance is so bad.

I want to make the images load blurry then on scroll event the images will bi loaded.

I'm using PHP and Zend framework

I'm searching for a java script library or php function that help me make an lazy load image but I wasn't able to find one that can be easy to use because I don't want to replace all the images manulay

I tried progressive-image.js the performance enhanced a little bit , my main goal is to make the minimum number of requests

is there any script that work the same as google images

i'v seen that code snippet

 function imageLoaded(e) {
   updateImage(e.target, 'loaded');
 }

function imageError(e) {
  updateImage(e.target, 'error');
}

function updateImage(img, classname) {
  // Add the right class:
  img.classList.add(classname);

  // Remove the data-src attribute:
  img.removeAttribute('data-src');

  // Remove both listeners:
  img.removeEventListener('load', imageLoaded);
  img.removeEventListener('error', imageError);
}

window.addEventListener('load', () => {
  Array.from(document.getElementsByTagName('img')).forEach(img => {
    const src = img.getAttribute('data-src');

    if (src) {
      // Listen for both events:
      img.addEventListener('load', imageLoaded);
      img.addEventListener('error', imageError);

      // Just to simulate a slow network:
      setTimeout(() => {
        img.setAttribute('src', src);
      }, 2000 + Math.random() * 2000);
    }
  });
})
body {
  margin: 0;
  height: 100%;
}

.images {
  width: 100%;
  height: 100%;
  background: #000;
  display: flex;
  align-items: center;
  overflow-x: scroll;
}

.margin-fix {
    border-right: 1px solid transparent;
    height: 16px;
}

img {
  width: 16px;
  height: 16px;
  margin: 0 64px;
  background-image: url("");
}

img.loaded {
  width: auto;
  height: 100%;
  margin: 0;
}

img.error {
  background: red;
  border-radius: 100%;

  /* You could add a custom "error" image here using background-image */
}
  <img
    src
    data-src="https://d39a3h63xew422.cloudfront.net/wp-content/uploads/2014/07/20145029/driven-by-design-the-incomparable-lancia-stratos-1476934711918-1000x573.jpg" />

  <img
    src
    data-src="https://car-images.bauersecure.com/pagefiles/76591/1752x1168/ford_racing_puma_01.jpg?mode=max&quality=90&scale=down" />

  <img
    src
    data-src="http://doesntexist.com/image.jpg" />

  <span class="margin-fix"></span>
</div>

Solution

  • nowdays it's more common that javascript is the dead weight. spending time decompressing, parsing and compiling - a larger image may sometimes be faster.

    https://developers.google.com/web/fundamentals/performance/optimizing-content-efficiency/javascript-startup-optimization/

    There is alternativ ways also like using loading="lazy" to only load stuff that is in the viewport. no javascript needed! also more SEO friendly.

    <img src="image.jpg" loading="lazy" alt="..." />
    <iframe src="video-player.html" loading="lazy"></iframe>
    

    also take some look at the request header and look at what they are requesting.

    • Browsers are sending accept-type with a bunch of formats. WebP may reduce the size more than jpg and still look good with lossy compression.

    • They may also send Save-Data request header to prefer reduced size over speed, perhaps serve them a smaller image that you then upscale.

    • some even send client-hints like Accept-CH: DPR, Width, Viewport-Width


    frankly i have disabled javascript in my mobile brave browser cuz so much junk shows ups all the time. cookie notif, ads, subscriptions, permission request, so i prefer if you just used loading="lazy"

    you could also take a look at srcset for responsive images https://developer.mozilla.org/en-US/docs/Learn/HTML/Multimedia_and_embedding/Responsive_images