真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

怎么接地氣地接入微前端

這篇文章將為大家詳細(xì)講解有關(guān)怎么接地氣地接入微前端,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。

成都創(chuàng)新互聯(lián)堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站建設(shè)、網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的錦屏網(wǎng)站設(shè)計(jì)、移動媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!

一 前言

微前端,這個概念已經(jīng)在國內(nèi)不止一次的登上各大熱門話題,它所解決的問題也很明顯,這幾個微前端所提到的痛點(diǎn)在我們團(tuán)隊(duì)所維護(hù)的項(xiàng)目中也是非常凸顯。

但我始終認(rèn)為,一個新的技術(shù)、浪潮,每每被討論最熱門的一定是他背后所代表的杰出思考。

"微前端就是...xx 框架,xx 技術(shù)"

這種話就有點(diǎn)把這種杰出的思路說的局限了,我只能認(rèn)為他是外行人,來蹭這個詞的熱度。

在我所負(fù)責(zé)的項(xiàng)目和團(tuán)隊(duì)中,已經(jīng)有非常大的存量技術(shù)棧和頁面已經(jīng)在線上運(yùn)行,任何迭代升級都必須要保證小心翼翼,萬無一失。

可以說,從一定程度來講,微前端所帶來的這些好處是從用戶體驗(yàn)和技術(shù)維護(hù)方面的,對業(yè)務(wù)的價值并不能量化體現(xiàn),落地這項(xiàng)技術(shù)秉著既要也要還要的指導(dǎo)方針。

我們對存量技術(shù)棧一定需要保持敬畏,隔離,影響范圍可控的幾個基本要素,然后再考慮落地實(shí)施微前端方案。

所以,在這個基本要素和指導(dǎo)方針下,要落地這項(xiàng)新的技術(shù),一定要充分了解當(dāng)前改造站點(diǎn)所存在的技術(shù)方案、占比以及當(dāng)前成熟的微前端框架已提供的能力差異,切勿生搬硬套。

二 背景

我所在團(tuán)隊(duì)維護(hù)的項(xiàng)目都是些 PC 操作后臺(Workstation),這些工作臺會存在不同的國家,不同時區(qū),不同合作方等等問題。

如果需要開發(fā)一個新的頁面需求,很可能投入進(jìn)來的開發(fā)人員都來自不同團(tuán)隊(duì),此時我們要在完成現(xiàn)有需求的同時還需要保證多個管理頁面的風(fēng)格統(tǒng)一,設(shè)計(jì)規(guī)范統(tǒng)一,組件統(tǒng)一,交互行為統(tǒng)一這非常困難。

當(dāng)該業(yè)務(wù)需要遷移到另外一個工作臺時,雖然需要保持邏輯一致,但導(dǎo)航欄、主題等卻不同。

當(dāng)前存量的方案都是采用 Java 直接進(jìn)行 Template 渲染出 HTML,經(jīng)過前面幾代前輩的迭代,不同系統(tǒng)中已經(jīng)存在幾種不同技術(shù)棧產(chǎn)出的頁面。

雖然都是 React 來實(shí)現(xiàn)的,但是前輩們都非常能折騰,沒有一個是按照常規(guī) React 組件形式開發(fā)出來的。

比如:

  • 大部分頁面是通過一份 JSON 配置,消費(fèi)組件生成的頁面。

  • 部分頁面是通過另外一個團(tuán)隊(duì)定義的 JSON 配置消費(fèi)組件生成的,與上面 JSON 完全不一樣。

  • 還有一部分頁面,是通過一套頁面發(fā)布平臺提供的 JS Bundle 加載出來的。

面對這樣的技術(shù)背景下,除了微笑的喊 MMP,含淚說著自己聽不懂的話(存在即合理,不難要你干嘛?),還得接地氣地出這樣一個落地方案。

三 方案 & 流程圖

首先,需要明確的分析出站點(diǎn)所有頁面,所需要加載的通用特性:

怎么接地氣地接入微前端

上述是精簡過后的一些通用功能特性,這里簡單做下介紹:

  • Layout Loader:用于加載不同工作臺的導(dǎo)航

  • DADA Loader:用于加載 JSON 配置的頁面

  • Source Code Loader:用于加載 JS Bundle

  • Micro Loader:用于處理微前端加載

  • Log Report:用于日志埋點(diǎn)

  • Time Zone:用于切換時區(qū)

  • i18n:用于切換多語言

  • Guider:用于統(tǒng)一管控用戶引導(dǎo)

除此以外可能還會存在以下這些頁面擴(kuò)展能力:

  • 安全監(jiān)控

  • 流量管控

  • 彈窗管控

  • 問卷調(diào)查

  • 答疑機(jī)器人

粗略統(tǒng)一歸類后來看,頁面的大體加載流程應(yīng)該是這樣:

怎么接地氣地接入微前端

四 實(shí)現(xiàn)細(xì)則

基于上述一個加載思路,首先需要做的是頁面加載路徑收口,需要保證所有頁面的加載入口是在一個統(tǒng)一的 Loader 下,然后才可以較為系統(tǒng)的處理所有頁面的加載生命周期。

在收斂的同時,同樣需要保持開放,對核心加載路徑要保持插件化開放,隨時支持不同的擴(kuò)展能力,渲染技術(shù)棧接入。

1 插件機(jī)制

所以,在主路徑上,通過 Loader 加載配置進(jìn)行處理,這份配置在主路徑中提供上下文,然后交由插件進(jìn)行消費(fèi),如圖所示:

怎么接地氣地接入微前端

舉個例子,拿一個獨(dú)立的 JS Bundle 類型的子應(yīng)用來說:

通過上述的 Plugin 引入,即可開啟和消費(fèi)不同的配置。

這里引入了 Layout Plugin,該插件會消費(fèi) hfType 字段然后去加載對于的 Layout 資源提供 Container 交給下一個環(huán)節(jié)。

按照配置,當(dāng)前頁面開啟了微前端,那么 Micro Loader 將會消費(fèi)提供下來的 Container,然后建立沙箱(這里基于 qiankun),再提供 Container 出來。

最后交由 SourceCode Plugin 進(jìn)行 Bundle 加載運(yùn)行和渲染。如果這里是另外一種渲染協(xié)議或者技術(shù)棧,則可以根據(jù)不同配置交由不同插件消費(fèi) Container。

這個過程中,每個環(huán)節(jié)的插件是不依賴的,可插拔的。

比如:

如果不加載 Layout Plugin 將不會消費(fèi) hfType 字段,也就不會將 Layout 插件邏輯注入到getContainer方法中,那么將直接得到由最外層下穿的 Container 進(jìn)行渲染,也就不會有菜單相關(guān)透出。

如果不加載 Micro Plugin 同樣不會有微前端的邏輯注入,也就不會建立沙箱,那么頁面渲染流程將會按照常規(guī)模式繼續(xù)運(yùn)行。

2 安全遷移

對于我所在團(tuán)隊(duì)負(fù)責(zé)的項(xiàng)目來說,萬萬做不得一刀切的方案,所以針對現(xiàn)有存量頁面,需要完整分析當(dāng)前存量技術(shù)棧:

怎么接地氣地接入微前端

針對上述存量頁面來說,需要從左到右分批進(jìn)行頁面級別控制上線部署,對于左側(cè)部分頁面甚至需要做些項(xiàng)目改造后才可部署接入上線。

這類遷移測試需要處理出一套自動化 e2e 測試流程,通過分批遷移同時梳理出 微前端注冊表 。

有了這兩項(xiàng)流程保證及范圍控制,當(dāng)前方案所上線內(nèi)容完全可控,剩下要處理的大部分就是較為重復(fù)的體力活了,覆蓋率也可量化。

3 微前端形態(tài)

按照上述方案遷移,那么預(yù)期的微前端形態(tài)將會是:

  • 每個開啟微前端的頁面都可成為主應(yīng)用。

  • 微前端是插件可選項(xiàng),如果因?yàn)槲⑶岸藢?dǎo)致的業(yè)務(wù)異??呻S時關(guān)閉。

  • 同為微前端的頁面路由相互之間切換可實(shí)現(xiàn)局部刷新形態(tài),而跳轉(zhuǎn)至非微前端注冊表中的頁面則會直接頁面跳轉(zhuǎn)。隨著微前端頁面覆蓋率提高,局部刷新的覆蓋率也會逐漸提高。

  • 可通過不同擴(kuò)展插件,加載不同技術(shù)棧類型的存量頁面,轉(zhuǎn)換為對應(yīng)子應(yīng)用。

怎么接地氣地接入微前端

在 SchemaResolver 中的注冊和調(diào)用路徑如下:

怎么接地氣地接入微前端

透過技術(shù)看本質(zhì),微前端所代表的杰出思維,才是真正解決具體問題關(guān)鍵所在,只有解決了具體的業(yè)務(wù)問題,這項(xiàng)技術(shù)才有價值轉(zhuǎn)換。

不要為了微前端做微前端,不要為了小程序做小程序。

當(dāng)前,通過 SchemaResolver,可以針對不同角色提供不同的開放能力:

  • 針對平臺管理員,提供插件能力開放全局?jǐn)U展能力。

  • 針對頁面開發(fā)者,提供標(biāo)準(zhǔn)化接入方案路徑,提供多種技術(shù)棧接入能力,并無感知提供微前端,多語言,埋點(diǎn),菜單,主題加載等能力。解耦了不同系統(tǒng)公共能力,同時,這種方式可以讓頁面開發(fā)者快速將具體業(yè)務(wù)邏輯遷移到其他平臺。

  • 針對第三方接入者,不需要關(guān)心了解系統(tǒng)菜單、主題接入方式,提供統(tǒng)一的接入口徑,通過微前端隔離技術(shù)棧、隔離子應(yīng)用樣式。最后通過統(tǒng)一的頁面系統(tǒng)管控,輕松入住對應(yīng)平臺,同時可以全局看到站點(diǎn)頁面情況。

關(guān)于怎么接地氣地接入微前端就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。


網(wǎng)頁名稱:怎么接地氣地接入微前端
分享鏈接:http://weahome.cn/article/poscgc.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部