WebP 图片兼容性处理
前段时间在做图片的 WebP 格式升级,WebP 格式的图片在网络传输时可以节省流量,但是浏览器的兼容性并不好,这里收集整理了一些 WebP 图片兼容性处理的方案。
1.通过 picture 标签进行选择判断
<picture>
<source srcset="img/pic.webp" type="image/webp">
<source srcset="img/pic.jpg" type="image/jpeg">
<img src="img/pic.jpg">
</picture>
该种方法要求在每个要请求 webp 图片的标签下都要通过 picture 标签来进行兼容性处理,同时注意该标签在IE的兼容性并不是很好,不过已经比 webp 的兼容性好一些。
2.通过服务端判断请求头中的 Accept 的值判断是否支持 webp
通过 HTTP request header 中是否存在 Accept: image/webp
来判断,这种方法的缺点在于:很多时候我们的图片等静态资源都会放到 CDN 服务器上,在这个层面加上判断 webp 的逻辑会更麻烦一些
3.由浏览器端判断是否支持 WebP 格式
if(document.createElement('canvas').toDataURL('image/webp').indexOf('",
lossless: ""
};
return function(feature) {
var deferred = $.Deferred();
$("<img>").on("load", function() {
if(this.width === 2 && this.height === 1) {
deferred.resolve();
} else {
deferred.reject();
}
}).on("error", function() {
deferred.reject();
}).attr("src", images[feature || "basic"]);
return deferred.promise();
}
})();
var add = function(msg) {
$("<p>").text(msg).appendTo("#x");
};
hasWebP().then(function() {
add("Basic WebP available");
}, function() {
add("Basic WebP *not* available");
});
hasWebP("lossless").then(function() {
add("Lossless WebP available");
}, function() {
add("Lossless WebP *not* available");
});
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论