JavaScript自定義Webpack配置實(shí)現(xiàn)流程介紹
1 初始化并創(chuàng)建要被打包的文件
首先創(chuàng)建文件夾webpack-demo
(隨便起一個),用來演示打包過程。在該文件夾下終端運(yùn)行命令,對項(xiàng)目進(jìn)行初始化操作,對包進(jìn)行管理:
npm init # 輸入命令后一直敲回車即可 npm init -y # -y是yes的意思,在初始化時省去敲回車的步驟
命令成功運(yùn)行之后,該文件夾下出現(xiàn)了package.json
文件,文件內(nèi)容具體如下:
{ "name": "webpack-demo", "version": "1.0.0", "description": "", "main": "index.js", "scripts": { "test": "echo \"Error: no test specified\" && exit 1" }, "keywords": [], "author": "", "license": "ISC" }
然后在本地安裝webpack
和webpack-cli
,執(zhí)行以下命令:
npm install webpack webpack-cli --save-dev
該命令執(zhí)行完成之后,在當(dāng)前目錄下出現(xiàn)了node_modules
文件夾和package-lock.json
文件,目錄結(jié)構(gòu)如下:
在webpack-demo
文件夾下創(chuàng)建文件夾src
,在src
下創(chuàng)建兩個文件,index.js
和hello.js
,目錄結(jié)構(gòu)如下:
在hello.js
文件中編寫如下代碼:
function hello() { console.log("hello"); } export default hello;
在index.js
文件中編寫如下代碼:
import hello from "./hello"; hello();
到這一步我們的準(zhǔn)備工作就完成了,接下來在該示例上操作。
2 命令行配置
webpack-cli
給我們提供了豐富的終端命令行指令,可以通過以下命令查看:
npx webpack --help
我們看到有很多命令可以幫助我們進(jìn)行配置,接下來我們演示幾個。
# --entry 指定了入口文件為index.js
# --mode 指定模式為production生產(chǎn)環(huán)境
npx webpack --entry ./src/index.js --mode production
運(yùn)行該命令之后,我們可以看到目錄新出現(xiàn)了dist
文件夾,文件夾中有main.js
文件,該文件就是我們打包之后的文件。
那么dist
文件夾的名字和main.js
文件的名字可以自己定義嗎?答案是可以,但是我們需要在命令行中輸入其他的參數(shù)。
到這里我們發(fā)現(xiàn),命令行不方便也不直觀,而且不能保存我們的一些配置,因此webpack
為我們提供了通過自定義配置文件的方式幫助我們自定義配置參數(shù)。
3 配置文件配置
我們在webpack-demo
文件夾中新建文件webpack.config.js
文件,這個文件名不能隨意起,因?yàn)?code>webpack會自動讀取文件,在該文件中配置entry
和output
制定輸入和輸出的文件:
module.exports = { entry: "./src/index.js", // 設(shè)置入口文件 output: { filename: "bundle.js", // 指定輸出的文件 path: "./dist", // 指定輸出的路徑 } }
配置完成之后我們在終端運(yùn)行命令來打包文件:
npx webpack
結(jié)果我們可以看到,終端為我們報了錯,提示我們輸出路徑必須是一個絕對路徑。那么我們可以通過node
中的path
模塊來獲得當(dāng)前文件的路徑,通過該路徑來設(shè)置輸出路徑:
const path = require("path"); module.exports = { entry: "./src/index.js", // 設(shè)置入口文件 output: { filename: "bundle.js", // 指定輸出的文件 // path.resolve()把一個路徑或路徑片段的序列解析為一個絕對路徑 // __dirname是當(dāng)前文件所在的目錄 path: path.resolve(__dirname, "./dist"), // 指定輸出的路徑 } }
我們再執(zhí)行npx webpack
,我們發(fā)現(xiàn)打包成功了,不過終端提示我們還應(yīng)該設(shè)置一下mode
,我們在配置文件后添加上mode
即可。
const path = require("path"); module.exports = { entry: "./src/index.js", // 設(shè)置入口文件 output: { filename: "bundle.js", // 指定輸出的文件 // path.resolve()把一個路徑或路徑片段的序列解析為一個絕對路徑 // __dirname是當(dāng)前文件所在的目錄 path: path.resolve(__dirname, "./dist"), // 指定輸出的路徑 }, mode: "production" // 模式:生產(chǎn)環(huán)境 }
打包之后,我們可以看到dist
文件夾下面出現(xiàn)了bundle.js
文件,該文件就是我們打包之后的文件。
到此這篇關(guān)于JavaScript自定義Webpack配置實(shí)現(xiàn)流程介紹的文章就介紹到這了,更多相關(guān)JavaScript自定義Webpack 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
ES6 Generator函數(shù)的應(yīng)用實(shí)例分析
這篇文章主要介紹了ES6 Generator函數(shù)的應(yīng)用,結(jié)合實(shí)例形式分析了ES6 Generator函數(shù)異步操作與異常捕獲相關(guān)使用技巧,需要的朋友可以參考下2019-06-06使用Object.defineProperty為對象定義屬性
這篇文章主要為大家介紹了使用Object.defineProperty為對象定義屬性示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08Javascript中判斷一個值是否為undefined的方法詳解
這篇文章給大家詳細(xì)介紹了在Javascript中如何判斷一個值是否為undefined,對大家的日常工作和學(xué)習(xí)很有幫助,下面來一起看看吧。2016-09-09javascript十六進(jìn)制數(shù)字和ASCII字符之間的轉(zhuǎn)換方法
下面小編就為大家?guī)硪黄猨avascript十六進(jìn)制數(shù)字和ASCII字符之間的轉(zhuǎn)換方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-12-12微信小程序?qū)崿F(xiàn)的動態(tài)設(shè)置導(dǎo)航欄標(biāo)題功能示例
這篇文章主要介紹了微信小程序?qū)崿F(xiàn)的動態(tài)設(shè)置導(dǎo)航欄標(biāo)題功能,結(jié)合實(shí)例形式分析了微信小程序使用wx.setNavigationBarTitle接口動態(tài)設(shè)置導(dǎo)航欄標(biāo)題的相關(guān)操作技巧,需要的朋友可以參考下2019-01-01