摘要:年月日,開始讓支持無損壓縮和透明色通道的功能,而在年月日的引用實做中正式支持。根據(jù)較早的測試,的無損壓縮比網(wǎng)絡上找到的檔少了的文件大小,即使這些檔在使用和處理過,還是可以減少的文件大小。這兩種緩存方式是可以同時存在的。
??Webp推出那年,我剛剛考上高中。轉(zhuǎn)眼間,大學畢業(yè)將近一年,我依舊是那個青蔥少年!就像Webp一樣,還是那么年輕,時至今日尚未嶄露頭角,原因是各大瀏覽器對它的兼容依舊不是那么的友好。IE爸爸甚至至今都沒有要支持它的跡象。
webp維基百科:WebP最初在2010年發(fā)布,目標是減少文件大小,但達到和JPEG格式相同的圖片品質(zhì),希望能夠減少圖片檔在網(wǎng)絡上的發(fā)送時間。 2011年11月8日,Google開始讓WebP支持無損壓縮和透明色(alpha通道)的功能,而在2012年8月16日的引用實做libwebp 0.2.0中正式支持。根據(jù)Google較早的測試,WebP的無損壓縮比網(wǎng)絡上找到的PNG檔少了45%的文件大小,即使這些PNG檔在使用pngcrush和PNGOUT處理過,WebP還是可以減少28%的文件大小。
??簡單來說,Webp格式是一種圖片格式,它有更優(yōu)秀的圖片壓縮算法,并且能實現(xiàn)肉眼難以辨識的質(zhì)量差異,同時它還支持有損無損兩種壓縮模式。
??由于是谷歌的親兒子,所以安卓原生瀏覽器對Webp的支持還是比較樂觀的,Chrome桌面版和安卓版的支持也都比較好。國內(nèi)的瀏覽器也不同程度的對Webp做了很多支持。我去Can I Use上截了張圖過來:
??由此可見,市面上占有率比較大的瀏覽器對Webp的支持還是很不錯的,所以有必要使用起來。其實是之前無意間發(fā)現(xiàn)某寶和某東在使用,所以也想在這塊做一些優(yōu)化。
??有圖有真相,先看看優(yōu)化后的效果吧。
??使用前:
??使用后:
??可以很明顯的看到,僅僅這八張并不是特別大的圖片,便節(jié)省了59.3K的流量。下載時間也有明顯的縮短。如果你的web項目是類似于某寶某東那樣有著大量圖片,那么這塊節(jié)省的流量可想而知!
??市面上有一些圖片格式轉(zhuǎn)換工具,我這里就不一一列舉了。這里要講的可能是比較簡單的一種使用方式,因為我們的圖片等資源文件托管在阿里云oss上,它只需要你在請求url里面帶個參數(shù),就會自動返回你想要的圖片格式。各位看官,如果你們的情況和我不一樣,可能需要自己對圖片做一部分處理或者別的云存儲也有類似的解決方案。
??好的,言歸正傳,接下來說說我的解決方案。我們的Web是利用Vue實現(xiàn)的前后端同構(gòu)的,所以存在服務端渲染和客戶端渲染兩種情況,這就要求我們要分別在服務端和客戶端對瀏覽器是否支持Webp作出判斷,如果瀏覽器支持,就去oss取webp格式的圖片,否則繼續(xù)使用原本圖片格式。
??我所采取的方法是在封裝網(wǎng)絡請求的時候,做了一步判斷,然后把是否支持Webp的變量放到了環(huán)境變量中。由于網(wǎng)絡請求需要同時支持客戶端和服務端,所以我采用的是axios并自己做了一層封裝。
// 封裝axios createRequest = (req) => { // 如果在客戶端創(chuàng)建 if (process.client) { process.env.supportWebp = document.createElement("canvas").toDataURL("image/webp").indexOf("data:image/webp") === 0 } else { // 從服務端檢測客戶端是否支持webp if (req && req.headers) { process.env.supportWebp = req.headers.accept.indexOf("image/webp") > -1 }else{ process.env.supportWebp = false } } }
??其實無論是客戶端還是服務端,都可以采用判斷accept里面是否帶有"image/webp"的方式,但是有些童鞋說判斷accept方式有些瀏覽器不準確,所以我們在客戶端采用較為穩(wěn)妥的方式去判斷。
??每個人的框架或者環(huán)境可能不同,所以代碼不一定能照搬,只需理解這部分的思想:根據(jù)不同的環(huán)境判斷瀏覽器是否支持Webp。
??在使用的時候,對于頁面中的img,我寫了一個過濾器:
export function judgeWebp (src) { if(process.env.supportWebp + "" === "true"){ return src + "?x-oss-process=image/format,webp" } return src } const filters = { //......, judgeWebp } Object.keys(filters).forEach(key => { Vue.filter(key, filters[key]) })
??對于背景圖片,style動態(tài)綁定似乎是不能使用過濾器的,所以采用計算屬性的方式實現(xiàn)。各位看官如果有更好的方法歡迎提出來。
??到此為止,我們可以根據(jù)瀏覽器是否支持webp來獲取到不同格式的圖片了。另外,有些社區(qū)也有過利用第三方polyfill來實現(xiàn)瀏覽器兼容Webp的方案。但是似乎并不是那么的流行,追求穩(wěn)妥的情況下,我這里暫不使用,如果你有過類似的實踐,歡迎與我分享。
http緩存??webp的分享就到這里,接下來我們簡單聊聊http緩存。http緩存大致分為兩類,一類是強制緩存,另一類叫對比緩存。這兩種緩存方式是可以同時存在的。強制緩存,一聽這名字就威武霸氣,所以它的優(yōu)先級也是比較高的,就是說,如果強制緩存生效,對比緩存就不再執(zhí)行。另一個區(qū)別點就是,強制緩存如果生效,就不再和服務器交互了,對比緩存則需要每次都和服務器交互協(xié)商。
強制緩存??先說強制緩存。瀏覽器向服務器請求數(shù)據(jù),返回的header頭中會攜帶緩存規(guī)則。體現(xiàn)在Expires和Cache-Control這兩個屬性當中。
??Expires是HTTP 1.0的東西,可以說是歷史遺留產(chǎn)物了。它的值是到期時間,如果請求時間小于這個到期時間,就會采用緩存。我們一眼就能發(fā)現(xiàn)這個邏輯其實意義并不大,而且如果服務端和客戶端時間不一致,會有誤差產(chǎn)生。
??Cache-Control似乎是為彌補Expires的天生缺陷而生的。它倆如果同時存在,Expires則不會生效。它的取值可以為:
取值 | 含義 |
---|---|
private | 可被緩存,但不能在用戶之間共享 |
public | 可被緩存,并且在多用戶間共享 |
no-store | 不緩存 |
no-cache | 使用對比緩存與服務器交互 |
max-age=xxx | 設定緩存有效期(單位秒) |
??這里需要區(qū)別no-store和no-cache,謹記no-store是不做緩存,而no-cache是使用對比緩存。似乎翻譯過來很像,但是實際效果差很多,對于no-store這種不緩存,除非特殊情況,我們一般不使用。
對比緩存??我們再聊聊對比緩存。對比緩存主要分兩大塊,一塊兒是根據(jù)修改時間判斷緩存是否生效,另一塊是通過Etag(個人理解就是個hash值)來判斷。
Last-Modified && If-Modified-Since??Last-Modified是存在于返回的header中的,顧名思義,它告訴我們這個資源的最后修改時間。當瀏覽器再次發(fā)起請求的時候,會由If-Modified-Since帶著這個值到服務器去做對比,如果服務器發(fā)現(xiàn)這個值小于目前服務器上資源的Last-Modified,則會把新的文件返回,狀態(tài)碼200。如果大于等于則只返回攜帶304狀態(tài)碼的請求,通知瀏覽器這個值尚未失效。
??它的缺點是這里的時間值只能精確到秒。
Etag && If-None-Match??Etag可以理解為服務器給資源打的hash值,就類似于我們使用構(gòu)建工具打包資源文件后面會跟一條常常的字符串一樣,它保證資源文件的唯一性。Etag隨response返回給瀏覽器,同理瀏覽器下一次請求會由If-None-Match攜帶Etag的值去到服務器作比對。如果發(fā)現(xiàn)這個值不存在,說明本地的資源文件已經(jīng)失效,服務器返回新的資源文件給客戶端,狀態(tài)碼200。反之,返回304通知客戶端資源文件仍然生效。
??相較于對比最后修改時間的策略,它的優(yōu)點在于可以突破精確到秒的限制,另外如果我們有一些定期更新的文件,但是資源內(nèi)容不變,Etag的優(yōu)勢就更為明顯了。
??這里要提及的一點是,當Last-Modified和Etag策略同時生效的時候,Etag的優(yōu)先級更高。
結(jié)語??本來是想記錄一下webp的,但是既然是優(yōu)化,就順便寫了寫http緩存這塊的內(nèi)容。除此之外,各位還可以根據(jù)實際情況合理配置cdn以及nginx等的緩存,以實現(xiàn)更好的用戶體驗。優(yōu)化路上無止境,但愿我們都能往極致的方向去做。今天就聊到這兒,有什么說錯的地方還請各位看官批評指正,希望大家多多指教!
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/107960.html
摘要:開啟驗證上傳一張新圖片,使用手安卓版本訪問已支持域名的圖片,如果請求帶了,檢查返回圖片格式是否為如果舊的圖片未按預期返回,返回了或原圖可能是結(jié)點緩存,正常天后過期回源則會返回圖片。 對于圖片較多的網(wǎng)站,本文結(jié)合具體案例給出了如何基于CDN的sharpP自適應圖片無痛接入方案,據(jù)統(tǒng)計效果可在原圖基礎上節(jié)省60%-75%的流量。作者:陳忱 出處:騰云閣文章 目前移動端運營素材大部分依賴圖...
摘要:幾個月前面試的時候問我性能優(yōu)化我可能會開始背誦雅虎軍規(guī),加點,代碼層面稍稍講點,現(xiàn)在系統(tǒng)的梳理下性能優(yōu)化的方方面面本文涉及方面有代碼優(yōu)化網(wǎng)絡請求過程角度入手解析建立鏈接網(wǎng)絡往返時延數(shù)據(jù)傳輸網(wǎng)絡問題角度入手請求數(shù)量流量性能優(yōu)化測試工具代碼優(yōu)化 幾個月前面試的時候問我性能優(yōu)化我可能會開始背誦雅虎軍規(guī),加點webp,代碼層面稍稍講點,現(xiàn)在系統(tǒng)的梳理下性能優(yōu)化的方方面面 本文涉及方面有: 代...
摘要:幾個月前面試的時候問我性能優(yōu)化我可能會開始背誦雅虎軍規(guī),加點,代碼層面稍稍講點,現(xiàn)在系統(tǒng)的梳理下性能優(yōu)化的方方面面本文涉及方面有代碼優(yōu)化網(wǎng)絡請求過程角度入手解析建立鏈接網(wǎng)絡往返時延數(shù)據(jù)傳輸網(wǎng)絡問題角度入手請求數(shù)量流量性能優(yōu)化測試工具代碼優(yōu)化 幾個月前面試的時候問我性能優(yōu)化我可能會開始背誦雅虎軍規(guī),加點webp,代碼層面稍稍講點,現(xiàn)在系統(tǒng)的梳理下性能優(yōu)化的方方面面 本文涉及方面有: 代...
摘要:又拍云上線了從編碼解碼到分發(fā),完整的端到端的自適應解決方案提供視頻上傳視頻存儲視頻編碼視頻分發(fā)適配視頻解碼等功能。又拍云希望能以云服務的方式將大公司才能長期支付使用的提供給更多企業(yè)。 繼愛奇藝、樂視等視頻廠商宣布支持 H.265 高清視頻后,2014 年 4 月,搜狐視頻宣布正式上線視頻行業(yè)首個 H.265 高清大片專區(qū),可在線觀看 200 余部當下最火的超高清大片。國外 BBC 從 ...
閱讀 783·2023-04-25 20:47
閱讀 2550·2019-08-30 15:53
閱讀 959·2019-08-26 14:05
閱讀 904·2019-08-26 11:59
閱讀 1692·2019-08-26 11:43
閱讀 1693·2019-08-26 10:57
閱讀 1366·2019-08-23 18:23
閱讀 2683·2019-08-23 12:57