webp格式圖片介紹及用法總結(jié)
一、什么是webp,它有什么用?
WebP(發(fā)音:weppy)是一種同時提供了有損壓縮與無損壓縮(可逆壓縮)的圖片文件格式,派生自影像編碼格式VP8,被認為是WebM多媒體格式的姊妹項目,是由Google在購買On2 Technologies后發(fā)展出來,以BSD授權(quán)條款發(fā)布。
WebP支持的像素最大數(shù)量是16383x16383。有損壓縮的WebP僅支持8-bit的YUV 4:2:0格式。而無損壓縮(可逆壓縮)的WebP支持VP8L編碼與8-bit之ARGB色彩空間。又無論是有損或無損壓縮皆支持Alpha透明通道、ICC色彩配置、XMP詮釋數(shù)據(jù)。
WebP有靜態(tài)與動態(tài)兩種模式。動態(tài)WebP(Animated WebP)支持有損與無損壓縮、ICC色彩配置、XMP詮釋數(shù)據(jù)、Alpha透明通道。
webp是谷歌推出的一種圖片格式,它的優(yōu)點就是同等畫面質(zhì)量下,體積比jpg、png這些少了25%以上。
大家都知道移動互聯(lián)網(wǎng)時代,頁面大小和用戶留存息息相關(guān),更快的加載頁面才能讓更多用戶關(guān)注到你的內(nèi)容,而圖片一直都是頁面體積的大頭,拿我們的活動頁面來說,圖片占據(jù)了80%以上的頁面大小。所以使用webp的話,可以瞬間讓頁面大小下降1/4,不得不說是一個極具性價比的優(yōu)化點。
當然,它也不是沒有缺點,瀏覽器對于webp的解碼速度相對于jpg來說會慢一些,不過這和體積減小帶來的性能提升,可以忽略不計了。
那么既然webp這么好,為什么沒有大范圍使用呢?歸根結(jié)底還是webp是谷歌推出的,目前主流瀏覽器只有chrome和安卓支持。不過IOS也快支持了,期待ing^ ^。在caniuse上可以查到webp目前的兼容性。

二、使用webp的常規(guī)方法以及它們的優(yōu)劣
首先,我們需要一個工具把圖片轉(zhuǎn)成webp格式,這里就使用google的官方工具即可,鏈接。
這個裝好之后,你的控制臺就有了一個cwebp命令。運行cwebp -h,成功顯示幫助信息就表示安裝好了。

通過這個工具就可以生成webp圖片了,有了webp圖片之后,之后便是如何使用了,常見有兩種方案。
方案一:服務(wù)器端處理
這是最最最省心的方法了,支持webp圖片的瀏覽器在向服務(wù)器發(fā)送請求時,會在請求頭Accept中帶上image/webp。然后服務(wù)器就可以根據(jù)是否含有這個頭信息來決定是否返回webp圖片了。
這個方法只需要在web服務(wù)器那里做一些操作即可,十分簡單方便。
不過這個方案缺點也很明顯,首先通過請求頭檢測,某些設(shè)備可能不太準。其次,現(xiàn)在圖片等靜態(tài)資源都會放到CDN服務(wù)器上,那么在這個層面加上判斷webp的邏輯就有點麻煩了。
方案二:前端檢測是否支持webp然后再請求相應(yīng)格式的圖片
這個方法好處是十分穩(wěn)妥,通過特性檢查可以知道用戶的瀏覽器是否支持webp,壞處就是需要在業(yè)務(wù)代碼中加入檢測webp的邏輯。
通常做法是在頁面加載前先執(zhí)行一段webp的檢測,得出瀏覽器是否支持webp格式,把結(jié)果存入cookie中,在加載圖片時,如果是懶加載的圖片,那么根據(jù)是否支持webp來處理圖片路徑就好,如果不是懶加載的圖片,可以在后端渲染模板時,根據(jù)我們設(shè)置好的是否支持webp的cookie來判斷。
目前這些都是針對頁面通過img標簽引入圖片時兼容webp的方式。如果是css中引入的圖片,方案一般就是構(gòu)建兩套css,然后在后端模板中根據(jù)cookie判斷使用哪一套,或是在css中通過選擇器覆蓋,比如對于支持webp的瀏覽器,我們在html根節(jié)點上加上webps的類名,然后針對引入的圖片,通過這個類名做選擇器優(yōu)先級覆蓋,具體的我們在第三部分看著代碼細說。
三、我們是如何用上webp的
重點來了,下面來說說我們對webp的實戰(zhàn)。
首先說說我們這邊現(xiàn)狀吧,我們的圖片有兩種存放方式。對于一些動態(tài)圖片,比如商品圖,這些是存放在我們的圖片服務(wù)器上,這個服務(wù)器支持webp格式,只需要在圖片路徑后面加上參數(shù)t=5即可得到webp格式的圖片。
對于css引入的背景圖,我們存放在某個CDN上,這部分就麻煩了,不支持生成webp圖片,所以只能自己傳一份相應(yīng)的webp圖片上去。
而且由于各種原因和限制,我們無法采用上述說的服務(wù)器端處理方案,所以只能采用前端代碼處理的方式。我想有些公司沒使用webp可能也是這些原因,因為純前端處理確實挺繞的。
結(jié)合我們的業(yè)務(wù)情況,因為是運營活動頁,背景圖和商品圖基本各占一半,甚至背景圖更多,所以我們需要把css引入的圖片和img標簽引入的圖片都做webp兼容T T。
針對img標簽引入的圖片,由于我們的圖片服務(wù)器支持webp,而且我們的商品圖大多是懶加載,那么就簡單了,直接修改我們的懶加載插件就可以實現(xiàn),在替換真實圖片路徑的時候判斷一下是否支持webp,然后替換相應(yīng)的路徑就可以。
針對css引入的圖片,我們采取的方案是利用css的優(yōu)先級覆蓋,比如說如果瀏覽器支持webp,那么我們給html根節(jié)點上加上webps的類名。這樣比如我們寫
span{background-image:url(a.jpg)}
的時候,再寫上
.webps span{background-image:url(a.jpg.webp)}
這樣,支持webp格式的設(shè)備就會自動加載webp的圖片了。
當然這里你肯定會有兩個疑問
一是每次寫代碼的時候加上.webps再寫一遍工作量也太大了。
二是每張圖對應(yīng)的webp圖片是哪里來的?需要自己生成嗎?
針對這兩個問題,我們找到了相應(yīng)的解決方法,對于問題一我們使用css預(yù)處理器做到了生成對應(yīng)的webp的代碼。
問題二我們使用nodejs寫了一個腳本來監(jiān)控圖片文件夾,當圖片增加、修改、刪除時,它便會生成或刪除對應(yīng)的webp圖片。
說了這么多,我們一起來看一看代碼實現(xiàn)吧。
首先,我們需要在頁面最開始的部分加入一段webp的檢查代碼。這段代碼的作用就是檢查當前瀏覽器是否支持webp,如果支持,那么給html根節(jié)點加上webps的類名,以供css使用。并且在cookie中記錄一個名為webps,值為A的cookie,為期一年。這樣,之后就可以在css中使用webp類名做兼容處理,img標簽引入的圖片也可以通過cookie得知瀏覽器是否支持webp,然后做相應(yīng)處理,后端也可以通過cookie得知設(shè)備對webp的支持情況來做一些差別渲染。
這段代碼如下,需要注意的是這段代碼要在引入css前就加載,代碼的含義可以直接看注釋。
(function(doc) {
// 給html根節(jié)點加上webps類名
function addRootTag() {
doc.documentElement.className += " webps";
}
// 判斷是否有webps=A這個cookie
if (!/(^|;\s?)webps=A/.test(document.cookie)) {
var image = new Image();
// 圖片加載完成時候的操作
image.onload = function() {
// 圖片加載成功且寬度為1,那么就代表支持webp了,因為這張base64圖是webp格式。如果不支持會觸發(fā)image.error方法
if (image.width == 1) {
// html根節(jié)點添加class,并且埋入cookie
addRootTag();
document.cookie = "webps=A; max-age=31536000; domain=58.com";
}
};
// 一張支持alpha透明度的webp的圖片,使用base64編碼
image.src = '';
} else {
addRootTag();
}
}(document));然后我們處理img標簽引入的圖片,因為我們的圖片服務(wù)器支持webp,且用img引入的圖片都是通過懶加載來載入的,所以這部分我們處理起來比較簡單,在懶加載替換真實路徑的時候,判斷cookie中是否存在webps=A這個cookie來決定加載的圖片的url。
當然,如果你們不是懶加載的引入的圖片,那么可以在后端渲染的時候,通過我們寫入的cookie,來判斷是否使用webp圖片,也很方便。這部分代碼比較簡單,就不貼出來了。
然后是css中引入的圖片了,由于css不支持邏輯,我們現(xiàn)在能利用的就是html根節(jié)點的.webps的類名了。我們在SCSS中使用了這個mixin來加載圖片。代碼作用可以看下注釋。
/*
通過這個函數(shù)來引入圖片,例如:
#wrapper{ @include bg('../img/sample.jpg') }
這段代碼經(jīng)過編譯后便會生成如下兩句代碼
#wrapper{ background-image:url('../img/sample.jpg'); }
.webp #wrapper{ background-image:url('../img/sample.jpg.webp'); }
*/
@mixin bg($url) {
background-image: url($url);
@at-root(with: all) .webps & {
background-image: url($url + '.webp');
}
}如果用的是less,可以通過下面這段代碼來實現(xiàn)同樣的功能。
.mixin(@url) {
background-image: url(@url);
.webps & {
background-image: url('@{url}.webp');
}
}最后就是如何生成webp圖片了。對于css引入的圖片,由于是放在CDN上,我們需要自己生成對應(yīng)的webp圖片。
如何做到開發(fā)的時候自動配套生成webp圖片呢,開始我們想的是給我們的構(gòu)建工具寫個插件來實現(xiàn)編譯時候生成webp圖片,然而我們發(fā)現(xiàn)由于各個項目使用的構(gòu)建工具可能不一樣,比如fis3、webpack還有我們自己開發(fā)構(gòu)建工具的,太多了,針對每一個開發(fā)成本太高。所以我們決定用nodejs寫個小腳本,作用就是監(jiān)控我們的圖片文件夾,隨時生成配套的webp圖片,當圖片有增加、修改、刪除時,它會相應(yīng)的增加、修改、刪除對應(yīng)的webp圖片。
工具代碼如下。默認監(jiān)聽images文件夾,npm install 安裝依賴之后,直接node webp-monitor.js既可。當然,前提是你按照好了第二部分所說的谷歌官方的webp生成工具,或者簡單的說你的終端需要有cwebp這個命令才行。
/*
webp圖片生成
運行:npm install && npm start
程序依賴谷歌官方webp轉(zhuǎn)換工具cwebp
mac下安裝 brew install webp
windows下可以去google官方下載
安裝完成后運行cwebp -h 如果顯示了使用幫助則表示安裝成功
*/
const process = require('child_process');
const fs = require('fs');
const chokidar = require('chokidar');
const log = console.log.bind(console);
const ignoreFiles = /(^\..+)|(.+[\/\\]\..+)|(.+?\.webp$)/; // 忽略文件.開頭和.webp結(jié)尾的
let quality = 75; // webp圖片質(zhì)量,默認75
let imgDir = 'images'; // 默認圖片文件夾
// 得到對應(yīng)的webp格式的文件名,默認為文件名后加上.webp
function getWebpImgName(path) {
return `${path}.webp`;
}
// 得到shell命令
function getShellCmd(path) {
return `cwebp -q ${quality} ${path} -o ${getWebpImgName(path)}`;
}
// 監(jiān)控文件夾
var watcher = chokidar.watch(imgDir, {
ignored: path => {
return ignoreFiles.test(path);
},
persistent: true // 保持監(jiān)聽狀態(tài)
});
// 監(jiān)聽增加,修改,刪除文件的事件
watcher.on('all', (event, path) => {
switch (event) {
case 'add':
case 'change':
generateWebpImg(path, (status) => {
log('生成圖片' + getWebpImgName(path) + status);
});
break;
case 'unlink':
deleteWebpImg(getWebpImgName(path), (status) => {
log('刪除圖片' + getWebpImgName(path) + status);
});
break;
default:
break;
}
});
log('biubiubiu~~~ 監(jiān)控已經(jīng)啟動');
function generateWebpImg(path, cb) {
process.exec(getShellCmd(path), err => {
if (err !== null) {
cb('失敗');
log('請先運行cwebp -h命令檢查cwebp是否安裝ok。')
log(err);
} else {
cb('成功');
}
});
}
function deleteWebpImg(path, cb) {
fs.unlink(path, (err) => {
if (err) {
cb('失敗');
log(err)
} else {
cb('成功');
};
});
}到此這篇關(guān)于webp格式圖片介紹及用法總結(jié)的文章就介紹到這了,更多相關(guān)webp圖片格式內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持腳本之家!
相關(guān)文章

webp格式如何轉(zhuǎn)換為gif動圖?九雷圖片轉(zhuǎn)換器轉(zhuǎn)換webp格式的方法
九雷圖片轉(zhuǎn)換器用于轉(zhuǎn)換圖片格式的工具,該軟件支持圖片轉(zhuǎn)換、壓縮、剪裁等,想知道使用該軟件如何轉(zhuǎn)換webd格式的方法,需要的朋友可以閱讀了解下2023-08-03
用戶通過該軟件可以輕松的對自己電腦中文件進行轉(zhuǎn)換,并且軟件支持轉(zhuǎn)換導(dǎo)出為BMP、JPEG、PNG多種格式,軟件界面簡潔,易于上手2022-11-10
圖片批量轉(zhuǎn)webp助手不僅可以幫助用戶將大量的圖片轉(zhuǎn)換輸出位webp格式,并且轉(zhuǎn)換的速度也是很快,而且使用起來也是相當?shù)暮唵畏奖?/div> 2024-07-19
Photoshop WebP Format(Webp縮略圖插件) V0.5b9 最新版
Photoshop WebP Format(Webp縮略圖插件)是一款可以幫助用戶朋友在使用Photoshop的時候能夠創(chuàng)建和保存,編輯webp格式圖片的插件,歡迎需要的朋友下載使用2024-02-25
WebPShop(PS WebP插件) v0.4.3 最新免費版 x64
WebPShop是一個開源免費跨平臺的PS插件,讓Photoshop支持編輯保存WebP格式圖片,旨在為網(wǎng)站的圖片提供高質(zhì)量,低體積,簡單好用2023-08-13
WebP圖像查看轉(zhuǎn)換WidsMob WebP激活教程 附激活補丁下載
WebP圖像查看轉(zhuǎn)換器WidsMob WebP激活教程+激活文件下載地址!下面有詳細的安裝激活教程,需要的朋友一起看看吧2022-03-16
如何把webp轉(zhuǎn)換成jpg或png格式?webp轉(zhuǎn)成jpg或png格式方法
這篇文章主要介紹了如何把webp轉(zhuǎn)換成jpg或png格式?webp轉(zhuǎn)成jpg或png格式方法的相關(guān)資料,想要了解的朋友,不妨參考下本文內(nèi)容。2022-01-07
WebPFormat(webp圖片格式轉(zhuǎn)換器) v2.0 綠色免費版
WebPFormat工具是一款webp圖片格式轉(zhuǎn)換器,支持轉(zhuǎn)換JPG/PNG/BMP/GIF,支持批量選擇文件轉(zhuǎn)換,相信不少朋友會用到2021-12-29
WebP Format(WebP圖像縮略圖插件) V0.5b5 免費安裝版
WebP格式是谷歌開發(fā)的一種旨在加快圖片加載速度的圖片格式。圖片壓縮體積大約只有JPEG的2/3,并能節(jié)省大量的服務(wù)器帶寬資源和數(shù)據(jù)空間。但WebP是一種有損壓縮。相較編碼JPE2019-07-16
webp圖片在網(wǎng)上十分常見,在做前端的時候,需要做一個網(wǎng)頁背景或者其他效果的時候,總是無法拿來用,很煩惱,不過,現(xiàn)在有了應(yīng)對Photoshop打開、編輯和導(dǎo)出Webp格式圖片的方2023-08-13最新評論











