Webpack 5模塊聯邦會不會引發微前端的革命呢? 本文詳解

来源:https://www.cnblogs.com/chengxuyuanaa/archive/2020/06/12/13101024.html
-Advertisement-
Play Games

Webpack 5的模塊聯邦提供載入部分編譯好的代碼能力,這個似乎會成為微前端架構的標準實現。 Webpack只是我分享的一小點,我是08年出道的高級前端架構師,有問題或者交流經驗可以進我的扣扣裙 519293536 我都會儘力幫大家哦 引言 在當前的微前端實現中,我們需要通過一系列的技巧去實現。正 ...


Webpack 5的模塊聯邦提供載入部分編譯好的代碼能力,這個似乎會成為微前端架構的標準實現。

Webpack只是我分享的一小點,我是08年出道的高級前端架構師,有問題或者交流經驗可以進我的扣扣裙 519293536 我都會儘力幫大家哦

引言

 

 

在當前的微前端實現中,我們需要通過一系列的技巧去實現。正如上圖所示,微前端的公共依賴載入目前並沒有非常好的實現方案。然後,Webpack 5中的模塊聯邦將會改變這一現狀。

模塊聯邦可以去依賴一個遠程模塊,這個依賴會在運行時生效,並不影響編譯時。因此,這個遠程依賴的模塊就可以是一個微前端獨立模塊。同時,每個獨立模塊都可以申明公共的依賴庫,這樣也可以避免獨立模塊間的依賴包的冗餘和衝突。

這篇文章將一步步告訴你如何通過Webpack 5的模塊聯邦特性來搭建一個微前端應用。這裡可以找到源代碼

示例

這個例子首先包含一個空殼涵蓋兩個模塊(Home、Flights),這個空殼應用可以按需的載入各個微前端模塊。

 

 

下麵是微前端模塊的部分-Flights,這部分其實也可以獨立運行。

 

 

 

通過這樣的架構可以實現各個模塊的獨立開發發佈,同時有能夠按需的進行集成整合。

模塊聯邦

在過去要實現微前端的架構是非常困難的,尤其是像Webpack這類工具是需要在編譯階段保證全部代碼的完整性。懶載入是有可能的,但需要在編譯階段排除掉才行。

在微前端架構下,每個獨立模塊都需要獨立編譯打包,並且需要人工引入。大體的代碼如下:

import('http://other-microfrontend');
複製代碼

這樣的實現需要依賴external方式的JavaScript人工引入,在Webpack 5中這一實現方式將會得到改變。

模塊聯邦背後的原理非常簡單:宿主系統通過配置名稱來引用遠程模塊,同時在編譯階段宿主系統是不需要瞭解遠程模塊的,僅僅在運行時通過載入遠程模塊的入口文件來實現。

 

 

 

宿主系統實現

宿主系統用於引入遠程模塊。這個例子會載入一個遠程模塊mfe1/component,mfe1是配置的遠程模塊名,component是其中提供的一個文件。

const rxjs = await import('rxjs');

const container = document.getElementById('container');
const flightsLink = document.getElementById('flights');

rxjs.fromEvent(flightsLink, 'click').subscribe(async _ => {
    const module = await import('mfe1/component');
    const elm = document.createElement(module.elementName);
    […]    
    container.appendChild(elm);
});
複製代碼

在Webpack配置中,採用ModuleFederationPlugin可以來申明要使用的遠程模塊信息。

const ModuleFederationPlugin = require("webpack/lib/container/ModuleFederationPlugin");

[…]

plugins: [
  new ModuleFederationPlugin({
    name: "shell",
    library: { type: "var", name: "shell" },
    remotes: {
      mfe1: "mfe1"
    },
    shared: ["rxjs"]
  })
]
複製代碼

這樣遠程模塊mfe1就聲明完成了,Webpack在編譯階段就會把mfe1相關的引用都忽略,避免將其進行打包。

在shared中可以定義依賴的公共庫,這個例子就是rxjs。這樣就可以保證整個應用僅僅會載入rxjs庫一次,否則的話公共庫會被打包進入宿主應用,同時也會在各個子模塊中重覆出現。

當然,shared的公共庫需要保證是一樣的版本。同時,宿主系統需要通過dynamic import的方式進行載入:

import * as rxjs from 'rxjs';
複製代碼

遠程模塊的實現

遠程模塊也是一個獨立系統,這裡採用web component方式實現:

class Microfrontend1 extends HTMLElement {

    constructor() {
        super();
        this.attachShadow({ mode: 'open' });
    }

    async connectedCallback() {
        this.shadowRoot.innerHTML = `[…]`;
    }
}

const elementName = 'microfrontend-one';
customElements.define(elementName, Microfrontend1);

export { elementName };
複製代碼

當然,你可以採用任何一種前端框架來實現,通用的框架庫可以用shared的方式在宿主和遠程模塊之間實現公用。

在遠程模塊的Webpack配置中,也需要使用ModuleFederationPlugin,將模塊暴露出去。

output: {
      publicPath: "http://localhost:3000/",
      […]
 },
 […]
 plugins: [
    new ModuleFederationPlugin({
      name: "mfe1",
      library: { type: "var", name: "mfe1" },
      filename: "remoteEntry.js",
      exposes: {
        component: "./mfe1/component"
      },
      shared: ["rxjs"]
    })
]    
複製代碼

name定義了遠程模塊的配置名稱。通過遠程模塊名稱和暴露出來的組件名,宿主就可以遠程進行依賴引用:

import('mfe1/component')
複製代碼

最後,宿主還需要知道遠程模塊的url來真正引入。

宿主連接遠程模塊

宿主系統需要載入遠程的入口文件,這個文件是遠程模塊通過ModuleFederationPlugin打包產生的。

入口文件名定義在filename的配置中,這個例子定義為"remoteEntry.js"。微前端模塊的url定義在publicPath屬性上。

在宿主系統中引入遠程模塊入口文件:

<script src="http://localhost:3000/remoteEntry.js"></script>
複製代碼

 

 

在這個例子中,我們提供了兩個系統

  • 宿主系統:地址是localhost:5000,會載入遠程模塊入口文件
  • 遠程模塊:地址是localhost:3000,提供了遠程模塊組件

結論

Webpack 5的模塊聯邦機制給微前端勢必會帶來革命性的變化。遠程的模塊可以獨立編譯,然後在運行時進行載入,同時還能夠定義公共庫來避免重覆載入。

現在Webpack 5依舊還是beta版本,但我們已經可以預見在不久的將來,模塊聯邦將成為微前端架構中標準解決方案之一。

覺得我寫的不錯的話,交個朋友,我是08年出道的高級前端架構師,有問題或者交流經驗可以進我的扣扣裙 519293536 我都會儘力幫大家哦
本文的文字及圖片來源於網路加上自己的想法,僅供學習、交流使用,不具有任何商業用途,版權歸原作者所有,如有問題請及時聯繫我們以作處理


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 耗電優化最終目的:通過儘可能降低CPU、GPU功耗來降低手機電量消耗。 (1)儘可能少用定時器; (2)優化I/O操作(所謂的I/O操作也就是文件操作,我們簡稱為I/O操作。怎麼優化呢?儘量不要頻繁寫入小數據,最好批量一次性寫入。讀寫大量主要的數據時,考慮用dispatch_io,其提供了基於GCD ...
  • Hilt是Google Android官方新推薦的依賴註入工具. 基於Dagger, 面向Android定製, 可以和Dagger共存. ...
  • CSS:頁面美化和佈局控制 一、CSS的使用:CSS與html結合使用方式 1.內聯樣式 * 在標簽內使用style屬性指定css代碼,如: <div style="color:red;">hello css</div> 2.內部樣式 * 在head標簽內,定義style標簽,style標簽的標簽體 ...
  • TypeScript在Model中的高級應用 在MVC、MVVC等前端經典常用開發模式中,V、C往往是重頭戲,可能是前端業務主要集中這兩塊。結合實際業務,筆者更喜歡路由模式、插件式設計,這種在迭代和維護上更能讓開發者收益(不過你需要找PM協調這事,畢竟他們理解的簡化用戶體驗,多半是怎麼讓用戶操作簡單 ...
  • electron-vue報錯:Webpack ReferenceError: process is not defined 博客說明 文章所涉及的資料來自互聯網整理和個人總結,意在於個人學習和經驗彙總,如有什麼地方侵權,請聯繫本人刪除,謝謝! 問題截圖 問題說明 在搭建electron的項目的時候出 ...
  • 前置 點擊按鈕切換搜索引擎 搜索框跟隨切換改變樣式 使用 vue 最快了 template 為了方便擴展,使用 v-for 迴圈渲染出按鈕,綁定切換搜索引擎的 method , 傳入不同名稱以區別搜索引擎。按鈕的樣式也動態綁定。 輸入框動態綁定樣式,在點擊按鈕切換搜索引擎時,搜索框綁定的樣式對應的 ...
  • Vue 3尚未正式發佈,但是維護者已經發佈了Beta版本,供我們的參與者嘗試並提供反饋。 如果你想知道Vue 3的主要功能和主要變化是什麼,那麼我將在這篇文章中重點介紹一下,告訴你使用Vue 3 beta 9創建一個簡單的應用程式。 我將介紹儘可能多的新內容,包括fragments,teleport ...
  • 0. 前言 也許我們通過 jquery 的迴圈方法進行數組遍歷,但是當不符合條件時,怎麼跳出當前迴圈?(即用each方法內,當不滿足條件時想break跳出迴圈體,想continue繼續執行下一個迴圈遍歷),我們經常會習慣JS中的break何continue,但是使用之後沒有效果,因為在JQuery中 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...