HTMLImageElement:decoding 属性
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
HTMLImageElement
接口的 decoding
属性用于告诉浏览器如何解析图像数据。具体来说,在渲染其他的内容更新前,是否应该等待图像解码完成。
值
使用说明
decoding
属性提示浏览器是否应该在一个步骤中与其他任务一起执行图像解码("sync"
),或者允许在解码完成前渲染其他内容("async"
)。实际上,这两者之间的差异往往难以察觉,而存在差异的地方往往有更好的办法。
对于在视口内插入到 DOM 中的图像,"async"
可能导致无样式内容闪烁,而 "sync"
则可能导致一些卡顿。使用 HTMLImageElement.decode()
方法通常是实现原子渲染,同时不会耽误其他内容的更好的方法。
对于在视口外插入到 DOM 中的图像,现代浏览器通常会在图像滚动到可视范围之前对其进行解码,使用这两种值都不会有明显的区别。
示例
下面的示例中,当图像下载时,页面上可能会显示空图像。设置 decoding
无法避免这种情况。
const img = new Image();
img.decoding = "sync";
img.src = "img/logo.png";
document.body.appendChild(img);
图片下载后再插入时,decoding
属性才更有效:
async function loadImage(url, elem) {
return new Promise((resolve, reject) => {
elem.onload = () => resolve(elem);
elem.onerror = reject;
elem.src = url;
});
}
const img = new Image();
await loadImage("img/logo.png", img);
// 使用 `sync` 可确保其他内容只随图片一起更新
img.decoding = "sync";
document.body.appendChild(img);
const p = document.createElement("p");
p.textContent = "图像已全部加载!";
document.body.appendChild(p);
然而,更好的解决方案是使用 HTMLImageElement.decode()
方法。它提供了异步解码图片的方法,推迟直到图片完全下载并解码完成时才将图片插入 DOM,以此避免上述的空图片问题。当你需要将现有图片动态替换为新图片时,这特别有用,而且可以防止在解码图片的过程中代码以外的无关绘制被耽搁。
如果解码时间较长,使用 img.decoding = "async"
可以避免其他内容被耽搁。
const img = new Image();
img.decoding = "async";
img.src = "img/logo.png";
document.body.appendChild(img);
规范
Specification |
---|
HTML # dom-img-decoding |
浏览器兼容性
BCD tables only load in the browser
参见
HTMLImageElement.decode()
方法<img>
元素的decoding
属性- 图像的 decoding 属性有什么作用?(2023 年,载于 tunetheweb.com)