教程所示圖片使用的是 github 倉庫圖片,網速過慢的朋友請移步《webpack4 系列教程(十二):處理第三方 JavaScript 庫》原文地址。或者來我的小站看更多內容:godbmw.com
0. 課程介紹和資料
本節課的程式碼目錄如下:
本節課的package.json
內容如下:
{
"dependencies": {
"jquery": "^3.3.1"
},
"devDependencies": {
"webpack": "^4.16.1"
}
}
複製程式碼
1. 如何使用和管理第三方JS
庫?
專案做大之後,開發者會更多專注在業務邏輯上,其他方面則盡力使用第三方JS
庫來實現。
由於js
變化實在太快,所以出現了多種引入和管理第三方庫的方法,常用的有 3 中:
- CDN:
<script></script>
標籤引入即可 - npm 包管理: 目前最常用和最推薦的方法
- 本地
js
檔案:一些庫由於歷史原因,沒有提供es6
版本,需要手動下載,放入專案目錄中,再手動引入。
針對第一種和第二種方法,各有優劣,有興趣可以看這篇:《CDN 使用心得:加速雙刃劍》
針對第三種方法,如果沒有webpack
,則需要手動引入import
或者require
來載入檔案;但是,webpack
提供了alias
的配置,配合webpack.ProvidePlugin
這款外掛,可以跳過手動入,直接使用!
2. 編寫入口檔案
如專案目錄圖片所展示的,我們下載了jquery.min.js
,放到了專案中。同時,我們也通過npm
安裝了jquery
。
為了儘可能模仿生產環境,app.js
中使用了$
來呼叫 jq,還使用了jQuery
來呼叫 jq。
因為正式專案中,由於需要的依賴過多,掛載到window
物件的庫,很容易發生命名衝突問題。此時,就需要重新命名庫。例如:$
就被換成了jQuery
。
// app.js
$("div").addClass("new");
jQuery("div").addClass("old");
// 執行webpack後
// 瀏覽器開啟 index.html, 檢視 div 標籤的 class
複製程式碼
3. 編寫配置檔案
webpack.ProvidePlugin
引數是鍵值對形式,鍵就是我們專案中使用的變數名,值就是鍵所指向的庫。
webpack.ProvidePlugin
會先從npm
安裝的包中查詢是否有符合的庫。
如果webpack
配置了resolve.alias
選項(理解成“別名”),那麼webpack.ProvidePlugin
就會順著這條鏈一直找下去。
// webpack.config.js
const path = require("path");
const webpack = require("webpack");
module.exports = {
entry: {
app: "./src/app.js"
},
output: {
publicPath: __dirname + "/dist/",
path: path.resolve(__dirname, "dist"),
filename: "[name].bundle.js",
chunkFilename: "[name].chunk.js"
},
resolve: {
alias: {
jQuery$: path.resolve(__dirname, "src/vendor/jquery.min.js")
}
},
plugins: [
new webpack.ProvidePlugin({
$: "jquery", // npm
jQuery: "jQuery" // 本地Js檔案
})
]
};
複製程式碼
4. 結果分析和驗證
老規矩,根絕上面配置,先編寫一下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>Document</title>
</head>
<body>
<div></div>
<script src="./dist/app.bundle.js"></script>
</body>
</html>
複製程式碼
命令列執行webpack
進行專案打包:
在 Chrome 中開啟index.html
。如下圖所示,<div>
標籤已經被新增上了old
和new
兩個樣式類。證明在app.js
中使用的$
和jQuery
都成功指向了jquery
庫。