Webpack DevServer配置

DevServer

該文檔主要描述關(guān)于devserver的相關(guān)配置。(配置同webpack-dev-middleware兼容)

devServer(Object類型)

該配置會(huì)被webpack-dev-server使用,并從不同方面做定制。
下面是一個(gè)例子,使用gzips提供對(duì)dist/文件夾下內(nèi)容的訪問(wèn)。

devServer: {
contentBase: path.join(__dirname, "dist"),//對(duì)外提供的訪問(wèn)內(nèi)容的路徑
compress: true,//是否啟用gzip壓縮
port: 9000//提供訪問(wèn)的端口
}

當(dāng)server運(yùn)行后,在請(qǐng)求時(shí)會(huì)打印如下內(nèi)容

http://localhost:9000/
webpack result is served from /build/
content is served from dist/

打印出來(lái)的內(nèi)容會(huì)顯示,server在監(jiān)聽什么端口,提供的服務(wù)來(lái)來(lái)源于內(nèi)容(如來(lái)源于dist文件夾)。
如果以Node.js API的方式使用dev-server,則devServer中的配置將會(huì)被忽略。
需要將設(shè)置的options作為第二個(gè)參數(shù)進(jìn)行傳遞new WebpackDevServer(compiler,{...})通過(guò)Node.js API進(jìn)行配置的內(nèi)容參見此處

devServer.clientLogLevel(String 類型)

當(dāng)使用inline mode,devTools的命令行中將會(huì)顯示一些調(diào)試信息,
如:before loading,before an error 或 Hot Module Replacement被啟用。
這類調(diào)試信息,可能會(huì)讓輸出變得比較亂。
可以通過(guò)如下設(shè)置禁止顯示上述的調(diào)試信息。

clientLogLevel: "none"

其中的值可以是none,error,warninginfo
如果不設(shè)置默認(rèn)的log level 為info。
注意console一致都會(huì)顯示bundle error和warning。上面的配置只對(duì)log級(jí)別低的message有效。

devServer.compress(boolean 類型)

對(duì)所有請(qǐng)求啟用gzip壓縮

compress: true

devServer.contentBase(boolean string array類型)

設(shè)置server對(duì)外服務(wù)的內(nèi)容來(lái)源,只有在提供靜態(tài)文件訪問(wèn)的情況下才需要使用該配置。
devServer.publicPath會(huì)被用來(lái)設(shè)置提供bundles文件的位置,而且會(huì)優(yōu)先考慮該配置的路徑。
默認(rèn)情況下會(huì)使用當(dāng)前運(yùn)行命令的文件夾作為內(nèi)容源,可以使用如下配置對(duì)此進(jìn)行更改。

contentBase: path.join(__dirname, "public")

注意:建議使用絕對(duì)路徑,不要使用相對(duì)路徑
可以定義多個(gè)文件夾提供數(shù)據(jù)源。

contentBase: [path.join(__dirname, "public"), path.join(__dirname, "assets")]

禁止使用contentBase可以做如下設(shè)置

contentBase: false

devServer.filename(String)

該配置可以配置成lazy mode來(lái)減少便宜,lazy modee模式下默認(rèn)會(huì)在每次請(qǐng)求時(shí),
進(jìn)行一次便宜。使用filename,可以設(shè)置當(dāng)請(qǐng)求某個(gè)指定的文件時(shí),才執(zhí)行編譯。
如果output.filename被設(shè)置位bundle.js并且filename如下使用,
則僅僅會(huì)在請(qǐng)求bundle.js時(shí),進(jìn)行編譯。

lazy: true,
filename:"bundle.js"

如果是設(shè)置filename而不設(shè)置lazy mode,則不會(huì)有任何效果。

devServer.headers(object)

像所有的請(qǐng)求添加headers

headers: {
  "X-Custom-Foo": "bar"
}

devServer.historyApiFallback(boolean object)

當(dāng)使用html5 history api,將會(huì)在響應(yīng)404時(shí)返回index.html。想要開啟該功能進(jìn)行如下設(shè)置。

historyApiFallback: true

通過(guò)傳遞一個(gè)object來(lái)對(duì)該共呢個(gè)做更多的定制。

historyApiFallback: {
  rewrites: [
    { from: /^\/$/, to: '/views/landing.html' },
    { from: /^\/subpage/, to: '/views/subpage.html' },
    { from: /./, to: '/views/404.html' }
  ]
}

當(dāng)在路徑中使用.符號(hào),需要使用disableDotRule配置。

historyApiFallback: {
  disableDotRule: true
}

關(guān)于此處更多的信息,參考connect-history-api-fallback文檔.

devServer.host(string 該配置只能用于CLI)

指定使用的host。默認(rèn)情況下是localhost.
如果希望server被外部訪問(wèn),需要向下面來(lái)制定。

host: "0.0.0.0"

devServer.hot(boolean)

啟用webpack的Hot Module Replacement特性。

hot: true

devServer.hotOnly(boolean 只適用于CLI)

啟用Hot Module Replacement,當(dāng)編譯失敗時(shí),不刷新頁(yè)面。

hotOnly:true

devServer.https(boolean object)

默認(rèn)情況下dev-server使用http協(xié)議,通過(guò)配置可以支持https
https: true
通過(guò)該配置,會(huì)使用自簽名的證書,同樣可以自定義簽名證書。

https: {
  key: fs.readFileSync("/path/to/server.key"),
  cert: fs.readFileSync("/path/to/server.crt"),
  ca: fs.readFileSync("/path/to/ca.pem"),
}

該對(duì)象的配置項(xiàng)會(huì)直接傳遞給Node.js的HTTPS模塊。
更多內(nèi)容參見 HTTPS documentation .

devServer.inline(boolean 只適用于CLI)

切換dev-server的兩種模式,默認(rèn)情況server使用inline mode。
這種情況下,live reload及構(gòu)建信息的相關(guān)代碼會(huì)被插入到bundle中。
另外一種模式位iframe mode.使用iframe mode會(huì)在通知欄下方
顯示構(gòu)建信息,切換到iframe mode可以使用下方配置。

inline: false

使用Hot Module Replacement時(shí),建議使用inline mode。

devServer.lazy(boolean)

當(dāng)啟用lazy.dev-server會(huì)僅在請(qǐng)求時(shí)進(jìn)行編譯。
這意味著webpack不會(huì)監(jiān)控文件改變,所以稱該模式為lazy mode.
開啟lazy模式如下。
lazy: true

當(dāng)在lazy模式下,watchOptions將不會(huì)被啟用
如果在CLI下使用,需要確保inline mode被禁用

devServer.noInfo(boolean)

啟用noInfo,類似webpack bundle啟動(dòng)或保存的信息將會(huì)被隱藏,Errors和warnings仍會(huì)被顯示。
noInfo: true

devServer.overlay(boolean object)

在瀏覽器上全屏顯示編譯的errors或warnings。
默認(rèn)是關(guān)閉的。如果只想顯示編譯錯(cuò)誤。則如下配置

overlay: true

如果既想顯示erros也想顯示warnings,則如下配置

overlay: {
    warnings: true,
    errors:true
}

devServer.port(number 只適用于CLI)

指定服務(wù)監(jiān)聽的端口

port: 8080

devServer.proxy(object)

未來(lái)保證在同一域名下,請(qǐng)求一些在其他域名下的api接口時(shí)會(huì)用到該配置。
dev-server使用http-proxy-middleware包。
當(dāng)服務(wù)運(yùn)行于localhost:3000時(shí),可以使用如下配置啟用代理。

proxy: {
  "/api": "http://localhost:3000"
}

對(duì)/api/users的請(qǐng)求將會(huì)通過(guò)代理請(qǐng)求到http://localhost:3000/api/users.
如果不想將/api傳遞過(guò)去,需要重寫path:

proxy: {
  "/api": {
    target: "http://localhost:3000",
    pathRewrite: {"^/api" : ""}
  }
}

默認(rèn)情況下如果請(qǐng)求的服務(wù)是https的,并且證書是未認(rèn)證的的,則該錯(cuò)未認(rèn)證證書默認(rèn)是無(wú)法使用的。如果想要使用該證書。則需要進(jìn)行如下配置,關(guān)閉安全檢測(cè)。

proxy: {
  "/api": {
    target: "https://other-server.example.com",
    secure: false
  }
}

有時(shí),不希望代理所有請(qǐng)求,可以像bypass屬性傳遞一個(gè)function來(lái)實(shí)現(xiàn)該需求。
在function中,可以獲取到request,response以及proxy options。
該function必須返回false或返回被部署的文件路徑,而不是繼續(xù)去代理請(qǐng)求。

例子,對(duì)于瀏覽器的請(qǐng)求,只希望提供html網(wǎng)頁(yè)的訪問(wèn),而對(duì)于api請(qǐng)求,
則將請(qǐng)求代理到指定服務(wù)。

proxy: {
  "/api": {
    target: "http://localhost:3000",
    bypass: function(req, res, proxyOptions) {
      if (req.headers.accept.indexOf("html") !== -1) {
        console.log("Skipping proxy for browser request.");
        return "/index.html";
      }
    }
  }
}

devServer.public(string CLI only)

當(dāng)使用inline mode并代理到dev-server。內(nèi)鏈的客戶端代碼不知道應(yīng)該訪問(wèn)哪個(gè)域名。
他將會(huì)基于window.location來(lái)鏈接服務(wù)器,但是如果這樣做有問(wèn)題,
則需要使用public配置。
例子:dev-server被代理到nginx中配置的myapp.test

public: "myapp.test:80"

devServer.publicPath(string)

打包的文件將被部署到該配置對(duì)應(yīng)的path。
假設(shè)server運(yùn)行在http://localhost:8080output.filename設(shè)置位bundle.js.
默認(rèn)情況下publicPath/,所以最終生成的bundle文件可以通過(guò)如下路徑訪問(wèn)。
http://localhost:8080/bundle.js.
publicPath更改為一個(gè)文件夾

publicPath: "/assets/"

最終的生成文件的訪問(wèn)路徑為http://localhost:8080/assets/bundle.js.

publicPath的值,前后必須包含斜杠

也可以使用完整的url進(jìn)行制定,如果使用HMR則必須使用該種寫法。

publicPath: "http://localhost:8080/assets/"

最終的生成文件仍然通過(guò)http://localhost:8080/assets/bundle.js進(jìn)行訪問(wèn)。

建議將devServer.publicPath同output.publicPath配置成相同值

devServer.quiet(boolean)

當(dāng)啟用該配置,除了初始化信息會(huì)被寫到console中,其他任何信息都不會(huì)被寫進(jìn)去。
errors和warnings也不會(huì)被寫到console中。

quiet: true

devServer.setup(function)

通過(guò)該function可以訪問(wèn)Express app對(duì)象,添加自定義的middleware。
舉例,為某個(gè)路徑添加自定義處理

setup(app){
  app.get('/some/path', function(req, res) {
    res.json({ custom: 'response' });
  });
}

devServer.staticOptions

能夠?qū)νㄟ^(guò)contentBase配置部署的靜態(tài)文件進(jìn)行高級(jí)配置。
具體配置查看Express文檔

staticOptions: {
  redirect: false
}

注意,該配置僅當(dāng)contentBase配置為string時(shí)起作用

devServer.stats(string object)

針對(duì)bundle打印的信息進(jìn)行精確控制。
使用場(chǎng)景為,當(dāng)只想看一些想看到的信息,而不想看到所有的打印信息,
這種情況下,使用quietnoInfo是不合適的,因?yàn)檫€希望關(guān)注一部分信息。
此種場(chǎng)景下就需要使用stats來(lái)控制日志內(nèi)容的輸出。

stats有一些可用的預(yù)設(shè)值

Preset Alternative Description
errors-only none 只在產(chǎn)生error時(shí)打印日志
minimal none 只打印errors或文件第一次被編譯時(shí)
none false 禁止打印日志
normal true 標(biāo)準(zhǔn)打印日志
verbose none 打印所有日志

示例:只顯示bundle中的errors

stats: "errors-only"

stats提供了很多細(xì)力度的對(duì)日志信息的控制。可以詳細(xì)指定希望打印的信息。

stats: {
  // Add asset Information
  assets: true,
  // Sort assets by a field
  assetsSort: "field",
  // Add information about cached (not built) modules
  cached: true,
  // Add children information
  children: true,
  // Add chunk information (setting this to `false` allows for a less verbose output)
  chunks: true,
  // Add built modules information to chunk information
  chunkModules: true,
  // Add the origins of chunks and chunk merging info
  chunkOrigins: true,
  // Sort the chunks by a field
  chunksSort: "field",
  // Context directory for request shortening
  context: "../src/",
  // `webpack --colors` equivalent
  colors: true,
  // Add errors
  errors: true,
  // Add details to errors (like resolving log)
  errorDetails: true,
  // Add the hash of the compilation
  hash: true,
  // Add built modules information
  modules: true,
  // Sort the modules by a field
  modulesSort: "field",
  // Add public path information
  publicPath: true,
  // Add information about the reasons why modules are included
  reasons: true,
  // Add the source code of modules
  source: true,
  // Add timing information
  timings: true,
  // Add webpack version information
  version: true,
  // Add warnings
  warnings: true
};

當(dāng)配置了quietnoInfo時(shí),該配置不起作用

devServer.watchContentBase(boolean)

設(shè)置server監(jiān)控通過(guò)devServer.contentBase設(shè)置的文件。
在文件改變時(shí)會(huì)進(jìn)行頁(yè)面刷新,默認(rèn)情況下該配置是禁止的。

watchContentBase: true

devServer.watchOptions(object)

對(duì)文件更改的監(jiān)控配置。
webpack基于文件系統(tǒng)來(lái)獲取文件的改變。在某些場(chǎng)景下,是不起作用的。
比如,當(dāng)使用NFS或Vagrant。針對(duì)這種情況使用polling進(jìn)行監(jiān)控。

watchOptions: {
  poll: true
}

如果該操作對(duì)于文件系統(tǒng)來(lái)說(shuō)消耗比較大,可以設(shè)置在一定的間隔時(shí)間內(nèi)出發(fā)一次。
更多的配置參見WatchOptions

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,619評(píng)論 6 539
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,155評(píng)論 3 425
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人,你說(shuō)我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,635評(píng)論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,539評(píng)論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,255評(píng)論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,646評(píng)論 1 326
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,655評(píng)論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,838評(píng)論 0 289
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,399評(píng)論 1 335
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,146評(píng)論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,338評(píng)論 1 372
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,893評(píng)論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,565評(píng)論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,983評(píng)論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,257評(píng)論 1 292
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 52,059評(píng)論 3 397
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,296評(píng)論 2 376

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 134,816評(píng)論 18 139
  • 中文翻譯 ng help ng build 構(gòu)建您的應(yīng)用程序并將其放入輸出路徑(dist /默認(rèn)情況下)。 別名:...
    4ea0af17fd67閱讀 2,051評(píng)論 0 0
  • 原文首發(fā)于:Webpack 3,從入門到放棄 Update (2017.8.27) : 關(guān)于 output.pub...
    昵稱都被用完了衰閱讀 1,910評(píng)論 4 19
  • Development 本部分內(nèi)容,會(huì)涉及到三種開發(fā)工具。需要注意的是,不要再產(chǎn)品發(fā)布環(huán)境下使用這些工具 設(shè)置編輯...
    yftx_閱讀 2,419評(píng)論 0 2
  • 最近因?yàn)楣ぷ鞯氖拢恢焙苊Α@瞎m然嘴上不說(shuō),可是心里總是覺(jué)得我陪伴他不夠。某天早上,起床做完飯后,他醒了,...
    國(guó)國(guó)2580閱讀 345評(píng)論 0 1