webpack5之devServer的常用配置詳解
前言
devServer是為開發(fā)過程中, 開啟的一個本地服務(wù),在此總結(jié)一些常用的配置。供大家學(xué)習(xí),相互成長,相互進(jìn)步!
一. contentBase
devServer中contentBase對于我們直接訪問打包后的資源其實(shí)并沒有太大的作用,但如果我們打包后的資源,又依賴于其他的一些資源,那么就需要指定從哪里來查找這個內(nèi)容,這時候就需要配置contentBase
舉例:
module.exports = {
mode: "development",
entry: "./src/index.js",
output: {
filename: "bundle.js",
// 打包后的文件的輸出目錄
path: path.resolve(__dirname, "./build"),
publicPath: "/abc",
},
// 專門為webpack-dev-server
// devServer為開發(fā)過程中, 開啟一個本地服務(wù)
devServer: {
publicPath: "/abc",
}
}

如上方圖所示設(shè)置"./why/abc.js",但是這樣webpack serve打包后瀏覽器是無法通過相對路徑去找到這個文件夾的

所以應(yīng)設(shè)置為如下:

module.exports = {
mode: "development",
entry: "./src/index.js",
output: {
filename: "bundle.js",
// 打包后的文件的輸出目錄
path: path.resolve(__dirname, "./build"),
publicPath: "/abc",
},
// 專門為webpack-dev-server
// devServer為開發(fā)過程中, 開啟一個本地服務(wù)
devServer: {
** contentBase: path.resolve(__dirname, "./why"),
** watchContentBase: true, //實(shí)時監(jiān)聽contentBase文件變化
publicPath: "/abc",
}
}

二. hotOnly、hot、host配置
1. hotOnly、hot
hot 啟用 webpack 的 熱模塊替換 特性:
module.exports = {
//...
devServer: {
hot: true,
},
};
啟用熱模塊替換功能,在構(gòu)建失敗時不刷新頁面作為回退,使用 hot: 'only' 或hotOnly:true:
module.exports = {
//...
devServer: {
hot: 'only', //hotOnly: true,
},
};
2. host設(shè)置主機(jī)地址
默認(rèn)值是localhost; 如果希望其他地方也可以訪問,可以設(shè)置為 0.0.0.0;
提示: localhost 和 0.0.0.0 的區(qū)別:
localhost:本質(zhì)上是一個域名,通常情況下會被解析成127.0.0.1;
127.0.0.1:回環(huán)地址(Loop Back Address),表達(dá)的意思其實(shí)是我們主機(jī)自己發(fā)出去的包,直接被自己接收;
- 正常的數(shù)據(jù)庫包經(jīng)常 應(yīng)用層 - 傳輸層 - 網(wǎng)絡(luò)層 - 數(shù)據(jù)鏈路層 - 物理層 ;
- 而回環(huán)地址,是在網(wǎng)絡(luò)層直接就被獲取到了,是不會經(jīng)常數(shù)據(jù)鏈路層和物理層的;
- 比如我們監(jiān)聽 127.0.0.1時,在同一個網(wǎng)段下的主機(jī)中,通過ip地址是不能訪問的;
0.0.0.0:監(jiān)聽IPV4上所有的地址,再根據(jù)端口找到不同的應(yīng)用程序;
- 比如我們監(jiān)聽 0.0.0.0時,在同一個網(wǎng)段下的主機(jī)中,通過ip地址是可以訪問的
三. port、open、compress
port:設(shè)置監(jiān)聽的端口,默認(rèn)情況下是8080,不能設(shè)置為null,可以設(shè)置自動為auto
module.exports = {
//...
devServer: {
port: 8080,
},
};
open:告訴 dev-server 在服務(wù)器已經(jīng)啟動后打開瀏覽器。設(shè)置其為 true 以打開你的默認(rèn)瀏覽器。
module.exports = {
//...
devServer: {
open: true,
//在瀏覽器中打開指定頁面:open: ['/my-page']
//提供要使用的瀏覽器名稱,而不是默認(rèn)名稱
// open: {
// app: {
// name: 'google-chrome',
// },
// },
},
};
compress:是否為靜態(tài)文件開啟gzip compression:
module.exports = {
//...
devServer: {
compress: true,
},
};

四. Proxy代理
Proxy是我們開發(fā)中非常常用的一個配置選項(xiàng),它的目的設(shè)置代理來解決跨域訪問的問題。
舉例:
我們的一個api請求是 http://localhost:8888,但是本地啟動服務(wù)器的域名是 http://localhost:8000, 這個時候發(fā)送網(wǎng)絡(luò)請求就會出現(xiàn)跨域的問題。 所以將請求先發(fā)送到一個代理服務(wù)器,代理服務(wù)器和API服務(wù)器沒有跨域的問題,就可以解決我們的跨域問題了。
module.exports = {
//...
devServer: {
proxy: {
'/api': {
target: 'http://localhost:8888',
pathRewrite: {
"^/api": ""
},
secure: false,
changeOrigin: true,
},
},
},
};
target:表示的是代理到的目標(biāo)地址,比如 /api會被代理到 http://localhost:8888/api
pathRewrite:默認(rèn)情況下,我們的 /api 也會被寫入到URL中,即:http://localhost:8888/api, 如果希望刪除,可以使用pathRewrite;
secure: 默認(rèn)情況下,將不接受在 HTTPS 上運(yùn)行且證書無效的后端服務(wù)器。 如果希望支持,可以設(shè)置為false;
changeOrigin:它表示是否更新代理后請求的headers中host地址,一般設(shè)置為true
五. historyApiFallback
historyApiFallback是開發(fā)中一個非常常見的屬性,它主要的作用是解決SPA頁面在路由跳轉(zhuǎn)之后,進(jìn)行頁面刷新 時,返回404的錯誤。
- 配置 boolean值:默認(rèn)是false
module.exports = {
devServer: {
//如果設(shè)置為true,那么在刷新時,返回404錯誤時,會自動返回 index.html 的內(nèi)容;
historyApiFallback: true,
},
};
- 配置 object類型的值,設(shè)置rewrites屬性: 可以配置from來匹配路徑,決定要跳轉(zhuǎn)到哪一個頁面;
module.exports = {
//...
devServer: {
historyApiFallback: {
rewrites: [
{ from: /^/$/, to: '/views/landing.html' },
{ from: /^/subpage/, to: '/views/subpage.html' },
{ from: /./, to: '/views/404.html' },
],
},
},
};
devServer中實(shí)現(xiàn)historyApiFallback功能是通過connect-history-api-fallback庫的: For more options and information,查看 connect-history-api-fallback 文檔
以上就是webpack5之devServer的常用配置詳解的詳細(xì)內(nèi)容,更多關(guān)于webpack5 devServer配置的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Vue.js React與Angular流行前端框架優(yōu)勢對比
這篇文章主要為大家介紹了Vue.js React與Angular流行前端框架優(yōu)勢對比,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-03-03
lodash內(nèi)部方法getData和setData實(shí)例解析
本篇章我們將了解lodash里內(nèi)部關(guān)于Data的操作方法,重點(diǎn)關(guān)注getData、setData兩個內(nèi)部方法,同時由實(shí)現(xiàn)上引申其他內(nèi)部封裝的方法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08
微信小程序 sha1 實(shí)現(xiàn)密碼加密實(shí)例詳解
這篇文章主要介紹了微信小程序 sha1 實(shí)現(xiàn)密碼加密實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-07-07

