javascript - 如何为您的网站制作模糊的延迟图像加载?

标签 javascript php html css zend-framework

我有一个充满图像的网站,但网站性能非常糟糕。

我想让图像加载模糊,然后在滚动事件上加载图像。

我正在使用 PHP 和 Zend 框架

我正在寻找一个java脚本库或php函数来帮助我制作延迟加载图像,但我找不到一个易于使用的库,因为我不想手动替换所有图像

我尝试了progressive-image.js,性能增强了一点,我的主要目标是使请求数量最少

有没有与谷歌图片功能相同的脚本

我看过那个代码片段

 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>

最佳答案

如今,更常见的是 JavaScript 是沉重的负担。花时间解压缩、解析和编译 - 较大的图像有时可能会更快。

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

还有其他方法,例如使用 loading="lazy" 仅加载视口(viewport)中的内容。无需 JavaScript!也更适合 SEO。

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

还要查看请求 header 并了解他们请求的内容。

  • 浏览器正在发送带有多种格式的accept-type。 WebP 可能会比 jpg 减少更多的尺寸,并且在有损压缩的情况下仍然看起来不错。

  • 他们还可能发送 Save-Data 请求 header ,以减少尺寸而不是速度,也许为他们提供较小的图像,然后您再放大。

  • 有些甚至发送 client-hints像Accept-CH:DPR,宽度,视口(viewport)宽度

<小时/>

坦白说,我在我的移动勇敢浏览器中禁用了 javascript,因为总是出现太多垃圾。 cookie 通知、广告、订阅、权限请求,所以我更喜欢您只使用 loading="lazy"

您还可以查看 srcset 来获取响应式图像 https://developer.mozilla.org/en-US/docs/Learn/HTML/Multimedia_and_embedding/Responsive_images

关于javascript - 如何为您的网站制作模糊的延迟图像加载?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59881507/

相关文章:

php - Wordpress SQL 请求,其中包含 WHERE 子句中数组中的数据

html - 为什么文本在关闭页面时不隐藏?

javascript - Web:如何连续播放音频文件而不出现延迟?

php - 如何在 PHP >= 5.3 严格模式下向对象添加属性而不产生错误

javascript - 如何使用 HTML5 与 UDP 套接字通信?

php - Doctrine 2 自定义 ObjectMultiCheckbox 值

html - 使用/单选按钮和复选框的页面样式有问题

html - 选择框边框半径在 IE6 中不起作用

javascript - IE >= 8 的原型(prototype) Event.StopPropagation

javascript - 如何优化 Javascript 查找?