成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

Webpack實(shí)戰(zhàn) - 使用動(dòng)態(tài) entry 改善調(diào)試體驗(yàn)

oogh / 3752人閱讀

摘要:本文相關(guān)代碼已經(jīng)存放在,可自行下載使用多入口復(fù)習(xí)的優(yōu)勢(shì)不言而喻,因此在實(shí)際應(yīng)用中我們也常常使用它調(diào)試多入口應(yīng)用,所謂多入口是指多個(gè)頁面會(huì)使用多個(gè)入口文件,在官方教程介紹了如何配置這里指定了個(gè)入口文件,打包之后分別會(huì)在文件夾中生成個(gè)打包之后

本文相關(guān)代碼已經(jīng)存放在 dynamic-entry,可自行下載使用

0. 多入口 (復(fù)習(xí))

webpack 的優(yōu)勢(shì)不言而喻,因此在實(shí)際應(yīng)用中我們也常常使用它調(diào)試 多入口 應(yīng)用,所謂 多入口 是指多個(gè)HTML頁面會(huì)使用多個(gè)入口文件,在官方教程 MULTIPLE ENTRY POINTS 介紹了如何配置:

{
    entry: {
        a: "./a",
        b: "./b",
        c: ["./c", "./d"]
    },
    output: {
        path: path.join(__dirname, "dist"),
        filename: "[name].entry.js"
    }
}

這里指定了 3 個(gè)入口文件,打包之后分別會(huì)在 dist 文件夾中生成 3 個(gè)打包之后的 js 文件:a.entry.js、b.entry.js、c.entry.js,可被至少 3 個(gè)不同的 HTML 頁面直接引用;

上述是最基本的使用,實(shí)際中還可以使用 multiple-commons-chunks 等提高打包的速度、性能;

1. 動(dòng)態(tài) entry 的場(chǎng)景

像上面那樣直接應(yīng)用 Webpack 的多入口功能,在普通的工程項(xiàng)目中并不存在什么問題,還簡(jiǎn)單高效;

然而如果你使用 Webpack 構(gòu)建較大型的頁面系統(tǒng),遂著業(yè)務(wù)的擴(kuò)大,入口的數(shù)量會(huì)逐漸增多,縱使每個(gè)入口文件都很小,在調(diào)試的時(shí)候等所有的入口文件都 ready 所耗費(fèi)的時(shí)間也是非常巨大的,讓用戶等待太久顯然很不友好;

用戶等待時(shí)間隨著模塊數(shù)量而線性增加(見下圖):

假設(shè)業(yè)務(wù)模塊有100個(gè),而當(dāng)前自己僅僅需要調(diào)試 A 模塊,如果使用默認(rèn)的多模塊入口方式,用戶 必須等這100個(gè)模塊啟動(dòng)之后才能調(diào)試 A 模塊,很明顯這會(huì)讓用戶抓狂;

比較合理的做法是,無論當(dāng)前用戶模塊目錄下有多少個(gè)模塊,默認(rèn)都只其構(gòu)建一個(gè)模塊,當(dāng)用戶想要調(diào)試另外一個(gè)模塊的時(shí)候,再動(dòng)態(tài)添加一個(gè) entry 到 webpack 系統(tǒng)中,這就減少了用戶等待的時(shí)間,提高了調(diào)試時(shí)的用戶體驗(yàn)

2. 實(shí)現(xiàn)動(dòng)態(tài) entry 的原理

目前業(yè)界并沒有現(xiàn)成的動(dòng)態(tài) entry 方案,需要自己分析 webpack 源碼找到解決方案;(如果不清楚 webpack 流程的,可以參考 @七玨 同學(xué)的 細(xì)說webpack之流程篇)

2.1、先分析 webpack 源碼中處理單入口的 entry 情況,在 WebpackOptionsApply.js 有:

這里首先是加載 EntryOptionPlugin.js 然后觸發(fā)添加 entry 入口

然后觸發(fā) entry-option 事件節(jié)點(diǎn),將 contextentry 作為參數(shù)傳入

2.2、 繼續(xù)看 EntryOptionPlugin.js 文件,在 entry-option 事件節(jié)點(diǎn)中調(diào)用 SingleEntryPlugin 構(gòu)造函數(shù)構(gòu)建單入口模塊:

我們可以依樣畫葫蘆,利用官方的 SingleEntryPlugin 的對(duì)象來完成動(dòng)態(tài)添加入口的功能。

我們像平常那樣創(chuàng)建單入口文件配置文件

依據(jù) webpack(config) 獲取 compiler 實(shí)例;

然后調(diào)用 compiler.apply(new SingleEntryPlugin(process.cwd(),...); 新增一個(gè)構(gòu)建入口

通知 webpack 讓新入口生效

3. 示例
本節(jié)的代碼放在倉庫 dynamic-entry 中,可以到下載獲取

這里我們以 express 框架為例,講解如何實(shí)現(xiàn)動(dòng)態(tài) entry ;具體操作步驟如下:

下載 dynamic-entry 代碼:git clone https://github.com/boycgit/dynamic-entry

cd dynamic-entry && npm install && node server.js

啟動(dòng) web 服務(wù)(可訪問 http://localhost:3000 ),默認(rèn)只會(huì)構(gòu)建一個(gè) src/index1.js

然后訪問 http://localhost:3000/add,再去看命令行,你會(huì)發(fā)現(xiàn)現(xiàn)在會(huì)構(gòu)建 src/index1.jssrc/index2.js 這兩個(gè)文件,這就是所謂的動(dòng)態(tài) entry

簡(jiǎn)要分析一下源碼,在 server.js 中:

...
var SingleEntryPlugin = require("webpack/lib/SingleEntryPlugin");
var webpackDevMiddleware = require("webpack-dev-middleware");

...

var webpackDevMiddlewareInstance = webpackDevMiddleware(compiler, webpackDevMiddlewareParam);
app.use(webpackDevMiddlewareInstance); // 應(yīng)用針對(duì) express 框架的 webpack 調(diào)試中間件

...

var once = true;
// 新增入口
app.get("/add", function(req, res) {
  // 應(yīng)用單入口插件
  console.log("apply SingleEntryPlugin");
  compiler.apply(new SingleEntryPlugin(process.cwd(), "./src/index2.js","index2"));
  once && webpackDevMiddlewareInstance.invalidate(); // 強(qiáng)制重新構(gòu)建一次,不用調(diào)用多次,后續(xù)的觸發(fā)由webpack自己 hot reload
  once = false; // 置 once 就是 false
  res.send("already apply SingleEntryPlugin");
});

這里用到了 webpack-dev-middleware 模塊,是 webpack 調(diào)試用的 express 中間件,它提供調(diào)試時(shí)候?qū)?gòu)建的文件輸出到文件系統(tǒng),可以讓用戶訪問獲??;

注冊(cè) /add 路由,當(dāng)用戶訪問此頁面的時(shí)候會(huì)調(diào)用 compiler.apply 新增一個(gè)構(gòu)建入口

調(diào)用 webpackDevMiddlewareInstance.invalidate() 強(qiáng)制 webpack 重新構(gòu)建一次,這個(gè)方法只需要調(diào)用1次(因此這兒由 once 變量進(jìn)行控制),后續(xù)的觸發(fā)由webpack自己 hot reload

從上面的過程可見,動(dòng)態(tài) entry 實(shí)施的過程是借鑒 webpack 自身的 SingleEntryPlugin 插件進(jìn)行的,在可靠性方面有很大的保障;其余的代碼則是借用現(xiàn)有的 express 中間件獲取所需要的 compiler 等對(duì)象協(xié)助此過程;

4. 總結(jié)

目前動(dòng)態(tài) entry 之后已經(jīng)運(yùn)用在若干個(gè)內(nèi)部構(gòu)建器中,在應(yīng)用動(dòng)態(tài) entry 之后,明顯地改善了用戶體驗(yàn);

此篇文章希望能給有類似場(chǎng)景的同學(xué)提供幫助;

5. 參考文章

MULTIPLE ENTRY POINTS

細(xì)說webpack之流程篇

webpack 源碼解析

下面的是我的公眾號(hào)二維碼圖片,歡迎關(guān)注。

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/81124.html

相關(guān)文章

  • webpack 基礎(chǔ)與項(xiàng)目?jī)?yōu)化實(shí)踐總結(jié)

    摘要:前言本文基于,主要涉及基本概念基本配置和實(shí)際項(xiàng)目打包優(yōu)化。關(guān)于概念方面參考官網(wǎng),常用配置來自于網(wǎng)絡(luò)資源,在文末有相關(guān)參考鏈接,實(shí)踐部分基于自己的項(xiàng)目進(jìn)行優(yōu)化配置。同一文件中,修改某個(gè)影響其他。 前言:本文基于weboack4.x,主要涉及webpack4 基本概念、基本配置和實(shí)際項(xiàng)目打包優(yōu)化。關(guān)于概念方面參考官網(wǎng),常用配置來自于網(wǎng)絡(luò)資源,在文末有相關(guān)參考鏈接,實(shí)踐部分基于自己的項(xiàng)目進(jìn)行...

    Scorpion 評(píng)論0 收藏0
  • webpack4 中的最新 React全家桶實(shí)戰(zhàn)使用配置指南!

    摘要:安裝配置加載器配置配置文件配置支持自定義的預(yù)設(shè)或插件只有配置了這兩個(gè)才能讓生效,單獨(dú)的安裝是無意義的。 showImg(https://segmentfault.com/img/bVbjGNY?w=2847&h=1931); 想閱讀更多優(yōu)質(zhì)文章請(qǐng)猛戳GitHub博客,一年百來篇優(yōu)質(zhì)文章等著你! 最新React全家桶實(shí)戰(zhàn)使用配置指南 這篇文檔 是呂小明老師結(jié)合以往的項(xiàng)目經(jīng)驗(yàn) 加上自己本身...

    Towers 評(píng)論0 收藏0
  • 切圖崽的自我修養(yǎng)-[BUILD] webpack體驗(yàn)記錄

    摘要:體驗(yàn)記錄大法好退保平安打包工具前端工程化一直是前端的一塊重點(diǎn)之前構(gòu)建工具的選擇上,公司也是很早之前就從收攏為的確是個(gè)好工具,作為工具核心的依賴表是非常好的構(gòu)建思路,也是很多大公司一直在用的構(gòu)建工具但是個(gè)人用的非常不習(xí)慣生態(tài)不是很好它太大太重 Webpack體驗(yàn)記錄 webpack大法好 退fis保平安 打包工具前端工程化一直是前端的一塊重點(diǎn).之前構(gòu)建工具的選擇上,公司也是很早之前就從g...

    ZHAO_ 評(píng)論0 收藏0
  • 切圖崽的自我修養(yǎng)-[BUILD] webpack體驗(yàn)記錄

    摘要:體驗(yàn)記錄大法好退保平安打包工具前端工程化一直是前端的一塊重點(diǎn)之前構(gòu)建工具的選擇上,公司也是很早之前就從收攏為的確是個(gè)好工具,作為工具核心的依賴表是非常好的構(gòu)建思路,也是很多大公司一直在用的構(gòu)建工具但是個(gè)人用的非常不習(xí)慣生態(tài)不是很好它太大太重 Webpack體驗(yàn)記錄 webpack大法好 退fis保平安 打包工具前端工程化一直是前端的一塊重點(diǎn).之前構(gòu)建工具的選擇上,公司也是很早之前就從g...

    ralap 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<