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