淺談 Webpack 如何處理圖片(開發(fā)、打包、優(yōu)化)
從 webpack book 的 Loading Assets 一章中延申出來。
改善前端項目體驗中,很重要的點就是靜態(tài)資源的優(yōu)化。它是由于瀏覽器客戶端在同一時間針對同一 域名 的請求有一定資源限制。如果資源過多、過大就會使得頁面卡頓。
靜態(tài)資源中,又以圖片最為典型。那么我們在開發(fā)中該如何處理圖片呢?
webpack 是前端較為常用的手腳架工具,本文以它為例。
主要分為 開發(fā) 、 打包 、 優(yōu)化 三個方面來介紹
示例地址: webpack demo
開發(fā)
webpack 可以用使用url-loader 將靜態(tài)圖片轉(zhuǎn)化為 base64 編碼的字符串,并內(nèi)聯(lián)在對應(yīng)的腳本中。大幅度地較少了頁面的請求數(shù),所以在開發(fā)階段可以無限制地使用。具體方法
// npm install url-loader --save-dev
rules: [{
test: /\.(png|jpg)$/,
use: {
loader: 'url-loader',
},
}]
以 demo-example 為例,Gakki.jpg 被轉(zhuǎn)化為了 base 64 編碼的圖片。在開發(fā)階段,沒什么問題,但是如果在實際環(huán)境中,會發(fā)現(xiàn)一個很大的問題,將圖片越大轉(zhuǎn)化為base 64 編碼的字符串就越長,將會導(dǎo)致整個 Js 腳本的大小飆升。
打包
為了減小腳本的大小,我們需要告訴 webpack 什么情況下采用 url-loader 去內(nèi)聯(lián)圖片,什么情況下采用其他的 loader。所以首先需要對 url-loader 進(jìn)行配置
rules: [{
test: /\.(png|jpg)$/,
use: {
loader: 'url-loader',
options: {
limit: 15000,
name: '[name].[ext]',
},
},
}]
在 options 中設(shè)定一個閾值屬性 limit: 15000 ,表明當(dāng)圖片小于該閾值 15kb 時,采用內(nèi)聯(lián)形式加載。那么如果超過閾值,我們該怎么辦?
可以利用 fallback 屬性指定采用file-loader 來處理,具體見配置
options: {
limit: 15000,
fallback: 'file-loader',
name: 'images/[name].[hash].[ext]',
},
默認(rèn)情況下,file-loader 會返回 options 依據(jù) 文件內(nèi)容返回一個 MD5 Hash 來構(gòu)建文件名。
如果同時需要 file-loader 與 url-loader 的情況,需要設(shè)置 limit來做區(qū)分。
優(yōu)化
為了進(jìn)一步地優(yōu)化體驗,我們可以采用以下策略:
- 控制圖片質(zhì)量,壓縮圖片大??;
- 配置 <img /> 標(biāo)簽的 srcset 來適應(yīng)不同的屏幕;
- 合成雪碧圖,減少圖片資源請求數(shù);
- 使用占位圖。
控制圖片質(zhì)量,壓縮圖片大小
為了和 url-loader 配合,引入image-webpack-loader ,同時配置圖片的 loader
{
test: /\.(png|jpg)$/,
use: [
{
loader: 'url-loader',
// 同上
options,
},
{
loader: 'image-webpack-loader',
// 配置不同圖片的質(zhì)量
options: {
mozjpeg: {
progressive: true,
quality: 65,
},
optipng: {
enabled: true,
},
pngquant: {
quality: '65-90',
speed: 4,
},
gifsicle: {
interlaced: false,
},
webp: {
quality: 75,
},
},
},
],
}
然后運行 npm run build ,很明顯的發(fā)現(xiàn),圖片的大小有了明顯的變化。這種對于圖片的壓縮對于生產(chǎn)環(huán)境特別有價值,因為它減少了下載圖像資源所需的帶寬量,從而加快了站點或應(yīng)用程序的速度。
也可以采用 imagemin-webpack-plugin 插件。
配置 <img /> 標(biāo)簽的 srcset 來適應(yīng)不同的屏幕
resize-image-loader 和responsive-loader 可以生成 srcset 的圖片合集,可以在現(xiàn)代游覽器上獲得更好地體驗,同時可以更好地控制瀏覽器加載哪些圖像以及何時獲得更高的性能。
合成雪碧圖,減少圖片資源請求數(shù)
Spriting技術(shù)允許將多個較小的圖像組合成單個圖像。它對于Web開發(fā)很有價值,同時也避免了請求開銷。
webpack-spritesmith 能夠生成雪碧圖和 Sass / Less / Stylus mixins。必須設(shè)置 SpritesmithPlugin,將其指向目標(biāo)圖像,并設(shè)置生成的mixin的名稱。
使用占位圖
與以上對比,這個 loader 使用起來相對復(fù)雜,它加載圖像并將其轉(zhuǎn)化為 image / svg + xml URL 編碼數(shù)據(jù)。通常它可以與file-loader和url-loader一起使用,以便在加載實際圖像時顯示占位符。配置為
{
test: /\.(gif|png|jpe?g)$/i,
use: [
{
loader: 'image-trace-loader'
},
{
loader: 'url-loader',
options: {
limit: 8192
}
}
]
}
這樣,你在 loader 圖片時,就會獲得
// src 為圖片,trace 為loader生成的占位圖
import { src, trace } from './assets/images/gakki-363kb.jpg'
// 定義圖片組件為
export const img = ({ src, trace }) => {
const img = new Image()
img.src = trace
img.onload = function () {
img.src = src
}
return img
}
// 掛載在 document.body 上
document.body.appendChild(img({ src, trace }))
參考:
- webpack book
- webpack doc
- 若干 npm readme
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Webpack常見靜態(tài)資源處理-模塊加載器(Loaders)+ExtractTextPlugin插件
- 詳解vue-cli與webpack結(jié)合如何處理靜態(tài)資源
- vue-cli與webpack處理靜態(tài)資源的方法及webpack打包的坑
- vue填坑之webpack run build 靜態(tài)資源找不到的解決方法
- 淺談webpack4 圖片處理匯總
- webpack 靜態(tài)資源集中輸出的方法示例
- 在Webpack中用url-loader處理圖片和字體的問題
- webpack實現(xiàn)靜態(tài)資源緩存的方法
- vue項目之webpack打包靜態(tài)資源路徑不準(zhǔn)確的問題
- webpack5處理圖片、圖標(biāo)字體、多媒體等靜態(tài)資源文件
相關(guān)文章
解析利用javascript如何判斷一個數(shù)為素數(shù)
本文主要分享了利用javascript如何判斷一個數(shù)為素數(shù)的具體實例代碼,有需要的朋友可以作為參考看下2016-12-12
JavaScript面向?qū)ο蟪绦蛟O(shè)計創(chuàng)建對象的方法分析
這篇文章主要介紹了JavaScript面向?qū)ο蟪绦蛟O(shè)計創(chuàng)建對象的方法,結(jié)合實例形式分析了javascript使用object構(gòu)造函數(shù)和對象字面量來創(chuàng)建對象的相關(guān)操作技巧,需要的朋友可以參考下2018-08-08
BootstrapTable請求數(shù)據(jù)時設(shè)置超時(timeout)的方法
使用bootstrapTable獲取數(shù)據(jù)時,有時由于網(wǎng)絡(luò)或者服務(wù)器的原因,無法及時獲取到數(shù)據(jù),頁面顯示一直處于等待狀態(tài)。為了改善效果,考慮設(shè)置超時,請求發(fā)送后超時即顯示無數(shù)據(jù),過段時間重新發(fā)起請求2017-01-01
JS實現(xiàn)簡單的選擇題測評系統(tǒng)代碼思路詳解(demo)
本文給大家分享js實現(xiàn)簡單的選擇題測評系統(tǒng)實例代碼,非常不錯,具有參考借鑒價值,需要的朋友參考下吧2017-09-09
javascript創(chuàng)建cookie、讀取cookie
這篇文章主要介紹了javascript創(chuàng)建cookie、讀取cookie的操作方法,內(nèi)容簡單易學(xué),感興趣的小伙伴們可以參考一下2016-03-03
Flow之一個新的Javascript靜態(tài)類型檢查器
今天我們興奮的發(fā)布了 Flow 的嘗鮮版,一個新的Javascript靜態(tài)類型檢查器。Flow為Javascript添加了靜態(tài)類型檢查,以提高開發(fā)效率和代碼質(zhì)量,本文給大家分享Flow之一個新的Javascript靜態(tài)類型檢查器,感興趣的朋友一起學(xué)習(xí)吧2015-12-12
js判斷出兩個字符串最大子串的函數(shù)實現(xiàn)方法
下面小編就為大家?guī)硪黄猨s判斷出兩個字符串最大子串的函數(shù)實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-11-11

