webpack自動化打包webpack-dev-server的實現(xiàn)
在前面的章節(jié)中我們每次改完要打包的資源文件,和配置文件都是是輸入npx webpack
命令手動打包的,那么有沒有什么辦法可以監(jiān)聽到我們代碼的改動,在保存時就自動打包呢?
答案是當(dāng)然有,不然哪些框架的腳手架是怎么實現(xiàn)保存自動打包的呢,這就是本章要介紹的內(nèi)容,webpack-dev-server插件,自動打包
一、什么是webpack-dev-server
Webpack Dev Server
是一個基于Node.js
構(gòu)建的Web
服務(wù)器,它可以在本地開發(fā)環(huán)境中啟動一個實時的Web服務(wù)器,并且能夠自動編譯并且刷新瀏覽器,為前端開發(fā)提供了很大的便利。
Webpack Dev Server
支持熱模塊替換(HMR),即在應(yīng)用程序運(yùn)行中更新模塊而無需刷新整個頁面,它還提供了一些其它的特性包括壓縮、編譯、轉(zhuǎn)換、代碼分離等等。Webpack Dev Server
通常用來搭建本地開發(fā)環(huán)境,而部署時則需要使用其它的Web服務(wù)器
二、在webpack中配置
1. 下載安裝
npm i webpack-dev-server -D
2. 在webpack.config.js中配置使用
const path = require("path"); module.exports = { entry: "./src/main.js", output: { path: path.resolve(__dirname, "dist"), filename: "js/main.js", // 將 js 文件輸出到 static/js 目錄中 }, module: { rules: [], }, plugins: [], // 開發(fā)服務(wù)器 devServer: { host: "localhost", // 啟動服務(wù)器域名 port: "3000", // 啟動服務(wù)器端口號 open: true, // 是否自動打開瀏覽器 }, mode: "development", };
這個是個服務(wù),是和webpack五大核心配置屬性同一級的,我們需要新增devServer配置對象。
完整代碼如下:
webpack.config.js
// Node.js的核心模塊,專門用來處理文件路徑 const path = require("path"); const ESLintWebpackPlugin = require("eslint-webpack-plugin"); // 引入 ESLint 插件 const HtmlWebpackPlugin = require("html-webpack-plugin"); // 引入 html-webpack-plugin 插件 module.exports = { // 入口 // 相對路徑和絕對路徑都行 entry: "./src/main.js", // 輸出 output: { // path: 文件輸出目錄,必須是絕對路徑 // path.resolve()方法返回一個絕對路徑 // __dirname 當(dāng)前文件的文件夾絕對路徑 path: path.resolve(__dirname, "dist"), // filename: js文件輸出文件名 filename: "js/main.js", clean: true, // 自動將上次打包目錄資源清空 }, // 加載器 module: { rules: [ { // 用來匹配 .css 結(jié)尾的文件 test: /\.css$/, // use 數(shù)組里面 Loader 執(zhí)行順序是從右到左 use: ["style-loader", "css-loader"], }, { // 用來匹配.less結(jié)尾的文件 test: /\.less$/, use: ["style-loader", "css-loader", "less-loader"], }, { test: /\.s[ac]ss$/, use: ["style-loader", "css-loader", "sass-loader"], }, { // 用來匹配圖片文件 test: /\.(png|jpe?g|gif|webp)$/, type: "asset", parser: { dataUrlCondition: { maxSize: 10 * 1024, // 小于10kb的圖片會被base64處理 }, }, generator: { // 將圖片文件輸出到 images 目錄中 // 將圖片文件命名 [hash:8][ext][query] // [hash:8]: hash值取8位 // [ext]: 使用之前的文件擴(kuò)展名 // [query]: 添加之前的query參數(shù) filename: "images/[hash:8][ext][query]", }, }, { test: /\.(ttf|woff2?|map4|map3|avi)$/, type: "asset/resource", // 以文件資源的形式輸出 generator: { filename: "media/[hash:8][ext][query]", // 輸出到media目錄中 }, }, { test: /\.m?js$/, // 轉(zhuǎn)譯哪些文件 exclude: /(node_modules|bower_components)/, // 排除哪些文件夾中的js文件不用轉(zhuǎn)譯 // use: { loader: 'babel-loader', // options: { // presets: ['@babel/preset-env'] // 添加預(yù)設(shè),轉(zhuǎn)譯js文件 // } // } } ], }, // 插件 plugins: [ new ESLintWebpackPlugin({ // 指定檢查文件的根目錄 context: path.resolve(__dirname, "src"), }), new HtmlWebpackPlugin({ // 以 public/index.html 為模板創(chuàng)建文件 // 新的html文件有兩個特點(diǎn):1. 內(nèi)容和源文件一致 2. 自動引入打包生成的js等資源 template: path.resolve(__dirname, "public/index.html"), }), ], // 開發(fā)服務(wù)器 devServer: { host: "localhost", // 啟動服務(wù)器域名 port: "8888", // 啟動服務(wù)器端口號 open: true, // 是否自動打開瀏覽器 }, // 模式 mode: "development", // 開發(fā)模式 };
3. 自動打包命令
npx webpack serve
如上圖,執(zhí)行命令以后,webpack-dev-server會自動在本地啟動一個服務(wù),并為我們在瀏覽器運(yùn)行打包好的資源。
4. 體驗自動打包
這時我們?nèi)ジ囊幌滦枰虬Y源文件,并保存看看效果更改保存前:
更改保存后:
可以看到已經(jīng)幫我們自動打包并運(yùn)行到瀏覽器了
到此我們終于是結(jié)束了在開發(fā)環(huán)境下手動運(yùn)行打包后的資源文件的時代,進(jìn)一步解放雙手拉。
5. 內(nèi)存運(yùn)行
如圖,我們清空dist目錄下的所有文件,重新npx webpack serve
打包
可以看到打包成功,并重新運(yùn)行到了瀏覽器,但是dist目錄下依然是空的。這就證明了一點(diǎn),webpack-dev-server是在本地內(nèi)存中遠(yuǎn)行的,這也是咱本地開發(fā)環(huán)境需要的,至于dist目錄要如何才能出來,需要配置生產(chǎn)環(huán)境,在后續(xù)會更新哦。
到此這篇關(guān)于webpack自動化打包webpack-dev-server的實現(xiàn)的文章就介紹到這了,更多相關(guān)webpack自動化打包 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
javascript實現(xiàn)修改微信分享的標(biāo)題內(nèi)容等
這篇文章主要介紹了javascript實現(xiàn)修改微信分享的標(biāo)題內(nèi)容等,需要的朋友可以參考下2014-12-12CSS和JS標(biāo)簽style屬性對照表(方便js開發(fā)的朋友)
CSS和JS標(biāo)簽style屬性對照表(方便js開發(fā)的朋友),需要的朋友可以收藏下。2010-11-11IE6-IE9使用JSON、table.innerHTML所引發(fā)的問題
這篇文章主要介紹了IE6-IE9使用JSON、table.innerHTML所引發(fā)的問題 ,需要的朋友可以參考下2015-12-12js動態(tài)修改input輸入框的type屬性(實現(xiàn)方法解析)
本文是對js動態(tài)修改input輸入框的type屬性的實現(xiàn)方法。進(jìn)行了詳細(xì)的介紹,需要的朋友可以過來參考下,希望對大家有所幫助2013-11-11JS操作字符串轉(zhuǎn)換為數(shù)值并取整的代碼
這篇文章主要介紹了JS操作字符串轉(zhuǎn)換為數(shù)值并取整的代碼,代碼比較短,需要的朋友可以參考下2014-01-01JS實現(xiàn)頁面滾動到關(guān)閉時的位置與不滾動效果
這篇文章主要介紹了JS實現(xiàn)頁面滾動到關(guān)閉時的位置與不滾動效果,滾動有兩種方案,其一,利用路由中的meta,在離開頁面時緩存 top 信息,其二,利用keep-alive緩存整個頁面。但是僅限于沒有實時數(shù)據(jù)變動的頁面,需要的朋友可以參考下本文2022-06-06