前言:此節的開展是在上一節的基礎上進行的,(每一節都是從無到有編寫關於此節的知識),最後會附上相關完整代碼。上一節css
在src目錄下新建一個images文件夾,把須要的圖片放入images文件夾。圖片下載html
在index.html文件中增長一個放置div的標籤(須要注意的是這裏修改的是src下的index.html文件,不是dist下的),代碼以下:webpack
<div id="img"></div>
在src目錄下的css目錄下的index.css文件中編寫樣式,以下,web
src/css/index.css:npm
body{
background-color: #018eea;
color: red;
font-size: 32px;
text-align: center;
}
#img{
background-image: url(../images/webapck.jpg);
width:271px;
height:285px;
}
使用npm在終端安裝file-loader和url-loader。json
npm install --save-dev file-loader url-loader
關於file-loader和url-loader,下面瞭解一下:webpack-dev-server
(1)file-loader:解決引用路徑的問題,拿background樣式用url引入背景圖來講,咱們都知道,webpack最終會將各個模塊打包成一個文件,所以咱們樣式中的url路徑是相對入口html頁面的,而不是相對於原始css文件所在的路徑的。這就會致使圖片引入失敗。這個問題是用file-loader解決的,file-loader能夠解析項目中的url引入(不只限於css),根據咱們的配置,將圖片拷貝到相應的路徑,再根據咱們的配置,修改打包後文件引用路徑,使之指向正確的文件。ide
(2)url-loader:若是圖片較多,會發不少http請求,會下降頁面性能。這個問題能夠經過url-loader解決。url-loader會將引入的圖片編碼,生成dataURl。至關於把圖片數據翻譯成一串字符。再把這串字符打包到文件中,最終只須要引入這個文件就能訪問圖片了。固然,若是圖片較大,編碼會消耗性能。所以url-loader提供了一個limit參數,小於limit字節的文件會被轉爲DataURl,大於limit的還會使用file-loader進行copy。性能
安裝以後,開始使用loader,此時在loader使用時不須要用require引入,在plugins才須要使用require引入。ui
webpack.config.js文件:
//模塊:例如解讀CSS,圖片如何轉換,壓縮 module:{ rules: [ { test: /\.css$/, use: [ 'style-loader', 'css-loader' ] },{ test:/\.(png|jpg|gif)/ , use:[{ loader:'url-loader', options:{ limit:500000 } }] } ] },
註釋:
test:/.(png|jpg|gif)/是匹配圖片文件後綴名稱。
use:指定使用的loader和loader的配置參數。
limit:是把小於500000B的文件打成Base64的格式,寫入打包後的js中。
此處只是其中一種配置方式,其他可參考
爲何只使用了url-loader?
在配置loader時,咱們並無在webpack.config.js中使用file-loader,可是依然打包成功了。這個和file-loader和url-loader之間的關係有關。url-loader和file-loader是什麼關係呢?簡單的說,url-loader封裝了file-loader,url-loader不依賴於file-loader,即便用url-loader時,只須要安裝url-loader便可,不須要安裝file-loader,由於url-loader內置了file-loader。url-loader工做分兩種狀況:
1.文件大小小於limit參數,url-loader將會把文件轉爲DataURL(Base64格式);
2.文件大小大於limit,url-loader會調用file-loader進行處理,參數也會直接傳給file-loader。
也就是說,其實咱們只安裝一個url-loader就能夠了。可是爲了之後的操做方便,這裏就順便安裝上file-loader。
在終端使用webpack命令進行打包。
webpack
webpack打包以後,咱們並無看到在dist目錄下生成相關的圖片,這是由於被打包到了js中(base64),圖片被用代碼的形式放置在js中。所以大圖片不適合打包成base64格式。
在終端中執行npm run server命令,啓動咱們的服務,而後經過 http://localhost:1818/ 進行訪問。
訪問效果以下:
相關完整代碼:
src/index.html:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>webpack</title> </head> <body> <div id="img"></div> <div id="title"></div> </body> </html>
src/entry.js:
import css from './css/index.css'
document.getElementById('title').innerHTML='Hello Webpack';
src/css/index.css:
body{ background-color: #018eea; color: red; font-size: 32px; text-align: center; } #img{ background-image: url(../images/webapck.jpg); width:271px; height:285px; }
package.json:
{ "name": "webpack3", "version": "1.0.0", "description": "", "main": "index.js", "scripts": { "server": "webpack-dev-server" }, "keywords": [], "author": "", "license": "ISC", "devDependencies": { "css-loader": "^2.0.0", "file-loader": "^2.0.0", "html-webpack-plugin": "^3.2.0", "style-loader": "^0.23.1", "url-loader": "^1.1.2", "webpack": "^3.6.0", "webpack-dev-server": "^2.9.7" } }
webpack.config.js:
const path = require('path'); const uglify = require('uglifyjs-webpack-plugin'); const htmlPlugin= require('html-webpack-plugin'); module.exports={ //入口文件的配置項 entry:{ entry:'./src/entry.js', //這裏咱們又引入了一個入口文件 entry2:'./src/entry2.js', }, //出口文件的配置項 output:{ //輸出的路徑,用了Node語法 path:path.resolve(__dirname,'dist'), //輸出的文件名稱 filename:'[name].js' }, //模塊:例如解讀CSS,圖片如何轉換,壓縮 module:{ rules: [ { test:/\.css$/, use:['style-loader','css-loader'] }, { test:/\.(png|jpg|gif)/, use:[{ loader:'url-loader', options:{ limit:500000 } } ] } ] }, //插件,用於生產模版和各項功能 plugins:[ // new uglify(), new htmlPlugin({ minify:{ removeAttributeQuotes:true }, hash:true, template:'./src/index.html' }) ], //配置webpack開發服務功能 devServer:{ contentBase:path.resolve(__dirname,'dist'), //絕對路徑 host:'localhost', compress:true, port:1818 } }