一、根模塊、子模塊與惰性加載
成都創(chuàng)新互聯(lián)公司始終堅(jiān)持【策劃先行,效果至上】的經(jīng)營(yíng)理念,通過(guò)多達(dá)十載累計(jì)超上千家客戶的網(wǎng)站建設(shè)總結(jié)了一套系統(tǒng)有效的營(yíng)銷解決方案,現(xiàn)已廣泛運(yùn)用于各行各業(yè)的客戶,其中包括:成都地磅秤等企業(yè),備受客戶稱贊。先說(shuō)根模塊。一個(gè)ng2應(yīng)用至少要有一個(gè)根模塊,包含ng2自帶的BrowserModule,并聲明為引導(dǎo)模塊,在應(yīng)用啟動(dòng)時(shí)將從此模塊展開(kāi)。
隨著應(yīng)用的擴(kuò)大,所有的事情都在一個(gè)模塊中完成難免會(huì)變亂(某種程度上看ng1應(yīng)用就是這么做的,并且細(xì)分了控制器來(lái)拆分應(yīng)用,這其實(shí)浪費(fèi)了最頂層模塊的意義),所以自然而然能想到,可以將系統(tǒng)分為多個(gè)模塊,每個(gè)模塊都只做各自的事情而互不干擾,所以進(jìn)一步的思路就是,用來(lái)根模塊來(lái)引導(dǎo)程序并管理所有子模塊(通過(guò)路由定向以及為它們提供全局配置與服務(wù)實(shí)例),所有的具體業(yè)務(wù)就交給各個(gè)子模塊來(lái)完成。
然后會(huì)有一個(gè)問(wèn)題,那就是既然系統(tǒng)已經(jīng)被這么多個(gè)子模塊瓜分了,并且這些子模塊也不可能同時(shí)全部都會(huì)被使用,也就是只有其被激活時(shí)才有用,那仍然在應(yīng)用引導(dǎo)時(shí)從根模塊加載所有子模塊必然會(huì)導(dǎo)致性能的浪費(fèi)以及拖慢執(zhí)行速度。此時(shí)惰性加載模塊就派上用場(chǎng)了,將一個(gè)子模塊定義為惰性加載后,只有在通過(guò)路由激活此模塊時(shí)才會(huì)開(kāi)始加載此模塊(并且ng2甚至支持異步預(yù)加載,即后臺(tái)預(yù)加載懶加載的模塊,這樣當(dāng)懶加載模塊需要被加載時(shí)其實(shí)其已經(jīng)加載完成了,又加快了響應(yīng)速度)。
二、除了模塊之外
每個(gè)模塊都有自己的事情要做,通常包括:
引入其他模塊 這個(gè)在第三部分細(xì)說(shuō)
聲明模塊包含的組件、指令與管道 所有的組件、指令或管道都必須依附于某個(gè)模塊,并只在此模塊中可用。
定義模塊提供的服務(wù) 服務(wù)也有自己所屬的模塊,但由于服務(wù)是全局單例的,所以只要在一個(gè)模塊中提供之后,全局都通用。注:若多個(gè)模塊同時(shí)提供了服務(wù)(通常發(fā)生在模塊間混亂的import時(shí)),一般情況下ng2能識(shí)別并只保留一個(gè)實(shí)例,但在惰性加載的模塊中則會(huì)發(fā)生不可預(yù)計(jì)的錯(cuò)誤,所以一定要避免。
定義模塊將導(dǎo)出的組件、指令與管道(還可以是此模塊引入的模塊) 與(1配合使用,同樣在第三部分細(xì)說(shuō)。
三、模塊的關(guān)聯(lián)
模塊之間一定要有共享或繼承資源的方式,不然的話每個(gè)子模塊都必須實(shí)現(xiàn)可能用到的全部功能。
比如一個(gè)消息彈窗組件,不可能每個(gè)子模塊都自己聲明一個(gè)消息組件然后使用,這樣的維護(hù)壓力很大且代碼嚴(yán)重浪費(fèi)。
此時(shí)就用到了模塊的引入和導(dǎo)出——
模塊A可以引入另一個(gè)模塊B,然后A就可以使用B中導(dǎo)出的組件、管道和指令。
當(dāng)我們要使用系統(tǒng)指令(如ngIf、ngFor等)時(shí),也必須引入系統(tǒng)模塊,有一個(gè)巧妙的辦法就是實(shí)現(xiàn)上圖這樣的共享模塊,在引入系統(tǒng)模塊并導(dǎo)出的同時(shí)再導(dǎo)出自定義的其他指令、組件或管道。然后所有引入了此共享模塊的子模塊就能使用這些系統(tǒng)指令和共享指令了。
有一個(gè)基礎(chǔ)的問(wèn)題是服務(wù)需不需要導(dǎo)出,答案是否定的。服務(wù)不需要導(dǎo)出,因?yàn)榉?wù)是全局單例的,一旦被初始化,就已經(jīng)全局通用了,相反如果重復(fù)的導(dǎo)入提供了同一服務(wù)的模塊就可能發(fā)生問(wèn)題:
B提供服務(wù)B_S,A導(dǎo)入了B,C也導(dǎo)入了B。這種情況下ng2會(huì)找到兩處B_S的提供,但ng2尚能夠?qū)⑵浔3衷谝粋€(gè)實(shí)例B_S。但若模塊C為惰性加載的模塊,在C被創(chuàng)建時(shí),其實(shí)會(huì)重新初始化一個(gè)實(shí)例B_S,從C跳轉(zhuǎn)回到A時(shí),又會(huì)創(chuàng)建一個(gè)B_S,來(lái)回每次跳轉(zhuǎn)都是如此,結(jié)局就會(huì)變得混亂不堪。
對(duì)于服務(wù)更好的做法是寫一個(gè)核心模塊,專門提供全局服務(wù),保證此模塊只會(huì)被根模塊引用一次,然后所有的子模塊就都已經(jīng)可以使用這些全局服務(wù)了。
四、ng2模塊體系
最后給出一套ng2項(xiàng)目構(gòu)建的體系,這也是總結(jié)歸納了ng2官網(wǎng)的推薦得出的ng2項(xiàng)目的模塊體系。
總體思路就是:
> 1.根模塊負(fù)責(zé)全局的路由。
> 2.核心模塊負(fù)責(zé)全局服務(wù),也可以定義一些只在根模塊中使用的組件等,并只能由根模塊引入一次,不再導(dǎo)出。
> 3.共享模塊不做服務(wù)的提供,而是定義全局共享的組件等,以及幫助子模塊導(dǎo)入系統(tǒng)模塊,讓子模塊只需要導(dǎo)入此共享模塊就夠了。
> 4.子模塊內(nèi)部可以細(xì)分自己的子路由到具體的子組件,以及提供自己的服務(wù)等。
> 5.除了頁(yè)面入口模塊(即除了根模塊外的具體業(yè)務(wù)模塊)之外的其他子模塊均考慮寫成惰性加載的模塊,以提升頁(yè)面引導(dǎo)的速度減少性能浪費(fèi)。
> 6.當(dāng)需要一個(gè)比較通用的全局服務(wù)時(shí),可以將其加入CoreModule,也可以再創(chuàng)建一個(gè)僅被根模塊引入的特性模塊。進(jìn)一步的,甚至可以將此模塊發(fā)布到npm,這就需要更強(qiáng)的編碼能力和技術(shù)積累了。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。