如何为您的网站制作模糊的延迟图像加载?
how to make a blurry lazy image loading for your website?
我有一个充满图片的网站,但网站性能很差。
我想让图像加载模糊,然后在滚动事件中图像将双加载。
我正在使用 PHP 和 Zend 框架
我正在寻找一个 java 脚本库或 php 函数来帮助我制作延迟加载图像,但我找不到一个易于使用的函数,因为我不想替换所有图片 manulay
我试过progressive-image.js性能提升了一点,我的主要目标是发出最少的请求数
是否有与google 图片
相同的脚本
我看过那个代码片段
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 是自重。花时间解压缩、解析和编译 - 图像越大有时速度越快。
还有其他方法,例如使用 loading="lazy"
仅加载视口中的内容。不需要 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, Width, Viewport-Width
坦率地说,我已经在我的移动浏览器中禁用了 javascript,因为总是会出现这么多垃圾。 cookie 通知、广告、订阅、权限请求,所以我更喜欢你刚刚使用 loading="lazy"
您还可以查看响应式图像的 srcset https://developer.mozilla.org/en-US/docs/Learn/HTML/Multimedia_and_embedding/Responsive_images
我有一个充满图片的网站,但网站性能很差。
我想让图像加载模糊,然后在滚动事件中图像将双加载。
我正在使用 PHP 和 Zend 框架
我正在寻找一个 java 脚本库或 php 函数来帮助我制作延迟加载图像,但我找不到一个易于使用的函数,因为我不想替换所有图片 manulay
我试过progressive-image.js性能提升了一点,我的主要目标是发出最少的请求数
是否有与google 图片
相同的脚本我看过那个代码片段
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 是自重。花时间解压缩、解析和编译 - 图像越大有时速度越快。
还有其他方法,例如使用 loading="lazy"
仅加载视口中的内容。不需要 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, Width, Viewport-Width
坦率地说,我已经在我的移动浏览器中禁用了 javascript,因为总是会出现这么多垃圾。 cookie 通知、广告、订阅、权限请求,所以我更喜欢你刚刚使用 loading="lazy"
您还可以查看响应式图像的 srcset https://developer.mozilla.org/en-US/docs/Learn/HTML/Multimedia_and_embedding/Responsive_images