淺談angular懶加載的一些坑
寫在前面
最近在工作中接觸到angular模塊化打包加載的一些內(nèi)容,感覺中間踩了一些坑,在此標(biāo)記一下.
項(xiàng)目背景:
項(xiàng)目主要用到angularJs作為前端框架,項(xiàng)目之前發(fā)布的時(shí)候會把所有的前端腳本打包壓縮到一個(gè)文件中,在頁面初次訪問的時(shí)候加載,造成頁面初始載入緩慢,在此基礎(chǔ)上,提出按需加載,即只有當(dāng)用戶訪問某個(gè)模塊的時(shí)候,該模塊的腳本才會加載.
工具類:
項(xiàng)目使用grunt打包根據(jù)AMD規(guī)范,使用grunt-contrib-requirejs來壓縮合并模塊,同時(shí)用ocLazyLoad來完成angular模塊的懶加載.
項(xiàng)目進(jìn)程:
模塊打包
項(xiàng)目中代碼基本按照AMD規(guī)范來編寫,使用grunt-contrib-requirejs來將每一個(gè)模塊壓縮到一個(gè)js文件中.
問題一:在項(xiàng)目代碼中,各個(gè)模塊都會依賴第三方庫/項(xiàng)目中公共服務(wù)/項(xiàng)目中公共指令,如果不對這部分內(nèi)容進(jìn)行處理的話, grunt-contrib-requirejs會在壓縮每個(gè)模塊的時(shí)候,將其依賴的所有模塊都加載過來,然后壓縮到同一個(gè)js文件中.
應(yīng)對:將第三方庫/公共服務(wù)和指令分別壓縮為三個(gè)模塊,然后每個(gè)模塊的打包腳本中使用” exclude”將其移除.如下圖所示:

需要注意的是,公共模塊的模塊名 需要在相應(yīng)的路徑下有同名的js文件
按需加載
將腳本按模塊打包為一個(gè)個(gè)的js文件后,下一步的工作就是將根據(jù)用戶請求來加載不同的模塊,項(xiàng)目用使用ui-router來處理路由跳轉(zhuǎn),可以從route入手來完成模塊的懶加載.
具體方法是:在用戶操作路由跳轉(zhuǎn)時(shí),根據(jù)用戶要跳轉(zhuǎn)到的state,去加載此state所屬的模塊.基于此,需要添加一個(gè)state和模塊之間的映射,最開始的時(shí)候使用requireJS來加載,發(fā)現(xiàn)腳本可以加載進(jìn)來,但是angular中注冊的控制器/services/filter等均不起作用.調(diào)查發(fā)現(xiàn),angular在調(diào)用bootstrap方法之后注冊的控制器之類的服務(wù)不會再被調(diào)用.基于此,引入ocLazyLoad來加載(ocLazyLoad對angular源碼有一些注入修改).
至此為止,基本實(shí)現(xiàn)按需加載,但還有以下幾個(gè)問題:
模塊之間項(xiàng)目依賴
因?yàn)榇嬖谝恍┠K之間項(xiàng)目之間有強(qiáng)依賴,對此的處理是在配置文件中添加模塊之間的依賴關(guān)系,在加載某個(gè)模塊之前查看其是否有依賴模塊,如果有的話,優(yōu)先加載其依賴模塊,待依賴模塊加載完成后再去加載當(dāng)前模塊
指令懶加載;
Angular中可以通過$compile來實(shí)現(xiàn)指令之間的相互依賴,對此的處理是配置指令名和指令模塊的依賴,當(dāng)用到某個(gè)指令的時(shí)候,先去加載其模塊,然后執(zhí)行編譯方法.這種解決方案能解決大部分的指令依賴.
指令的位置問題.項(xiàng)目中大多用到的都是長頁面,每一個(gè)長頁面劃分為若干個(gè)區(qū)域,每一個(gè)區(qū)域都是一個(gè)指令.使用攔截的時(shí)候會有一個(gè)問題,就是每個(gè)指令加載時(shí)間的長短不一樣,先回來的指令會優(yōu)先append到dom上,從而導(dǎo)致頁面布局的不確定性.解決方案是,使用deffer機(jī)制,待所有指令加載/編譯完成后,再往dom樹上添加執(zhí)行.
指令之間的依賴:指令之間也存在項(xiàng)目依賴,對此的解決方案是將相互依賴的指令合并為一個(gè)模塊,打包到同一個(gè)腳本文件中.這個(gè)方案能解決大部分的指令依賴,但是無法解決初始化過程中的依賴.可能存在某個(gè)指令編譯的時(shí)候,其依賴的指令還未完成編譯.對于這樣的超級特殊例子,只有在頁面初始化的時(shí)候加載腳本和template.
以上就是在整個(gè)項(xiàng)目進(jìn)程中遇到的問題,基本每前進(jìn)一次都是踩著坑,好多東西都是第一次接觸,感覺還是學(xué)到了一些東西.可能好多問題的解決方案不是很明確.以上所有問題其他人都遇到過,只要用好搜索引擎,加上自己好好閱讀/理解別人的代碼.所有問題都可以得到圓滿的解決
關(guān)于這篇淺談angular懶加載的一些坑就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
AngularJS實(shí)現(xiàn)用戶登錄狀態(tài)判斷的方法(Model添加攔截過濾器,路由增加限制)
這篇文章主要介紹了AngularJS實(shí)現(xiàn)用戶登錄狀態(tài)判斷的方法,通過Model添加攔截過濾器,路由增加限制實(shí)現(xiàn)針對登陸狀態(tài)的判斷功能,需要的朋友可以參考下2016-12-12
詳解Angular路由動(dòng)畫及高階動(dòng)畫函數(shù)
本文主要講解了Angular的路由動(dòng)畫和高階動(dòng)畫函數(shù),對此感興趣的同學(xué),可以把代碼親自實(shí)驗(yàn)一下,理解其原理。2021-05-05
AngularJs bootstrap搭載前臺框架——基礎(chǔ)頁面
本文主要介紹AngularJs bootstrap搭載前臺框架基礎(chǔ)頁面的建設(shè),這里整理餓了相關(guān)資料及實(shí)現(xiàn)實(shí)例代碼,有興趣的小伙伴可以參考下2016-09-09
Angular4學(xué)習(xí)教程之DOM屬性綁定詳解
這篇文章主要給大家介紹了關(guān)于Angular4學(xué)習(xí)教程之DOM屬性綁定的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2018-01-01
AngularJS頁面訪問時(shí)出現(xiàn)頁面閃爍問題的解決
這篇文章主要介紹了AngularJS框架使用中出現(xiàn)頁面閃爍問題的解決方法,閃爍問題一般是初始化未加載完畢造成的,需要的朋友可以參考下2016-03-03
Angularjs Ng_repeat中實(shí)現(xiàn)復(fù)選框選中并顯示不同的樣式方法
今天小編就為大家分享一篇Angularjs Ng_repeat中實(shí)現(xiàn)復(fù)選框選中并顯示不同的樣式方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-09-09

