這期內(nèi)容當中小編將會給大家?guī)碛嘘PocLazyLoad和resolve怎么在ui-router中使用,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
在會昌等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務理念,為客戶提供成都網(wǎng)站制作、成都網(wǎng)站設計 網(wǎng)站設計制作按需開發(fā)網(wǎng)站,公司網(wǎng)站建設,企業(yè)網(wǎng)站建設,品牌網(wǎng)站制作,全網(wǎng)營銷推廣,外貿(mào)網(wǎng)站制作,會昌網(wǎng)站建設費用合理。1.AngularJS按需加載
AngularJS主要應用開發(fā)SPA(Single Page Application)項目,所以在小型項目中,services、filters和controllers都在index.html中加載。Google給的AngularJS官方的angular-seed和angular-phonecat都是這樣。
對于復雜一點,大型的項目,如果所有的內(nèi)容一開始就加載,對首頁的性能影響比較大,即使靜態(tài)javascript文件使用CDN,對性能還是有很大的影響。所有需要引入按需加載機制,而Angular1.x版本中,ocLazyLoad是一個不錯的按鈕加載解決方案。
2.ocLazyLoad的功能
ocLazyLoad: your solution for lazy loading with Angular 1.x
入門可以參照:ocLazyLoad快速入門,代碼也非常簡單:
1.引入ocLazyLoad文件,可以使用npm和bower來進行安裝
2.注入 oc.lazyLoad模塊
var myApp = angular.module("MyApp", ["oc.lazyLoad"]);
3. 在控制器中加載一個指定的模塊
myApp.controller("MyCtrl", function($ocLazyLoad) { $ocLazyLoad.load('testModule.js'); });
在實際項目中service和controller文件都是通過ocLazyLoad加載,并且是放在resolve中加載。代碼示例如下:
.state('detail',{ url:"/detail/:bookId", templateUrl:"/templates/detail.html", controller:"DetailController", controllerAs:'ctrl', resolve:{ load:['$ocLazyLoad',function($ocLazyLoad){ return $ocLazyLoad.load([ 'services/dataService.js' ]); }], currentBook:['$ocLazyLoad','$stateParams','$injector',function($ocLazyLoad,$stateParams,$injector){ var bookId=$stateParams.bookId; return $ocLazyLoad.load('services/booksService.js').then(function(){ return $injector.get('booksService').getBookById(bookId);; }); }] } })
3.resolve屬性
resolve在state配置參數(shù)中,是一個對象(key-value),每一個value都是一個可以依賴注入的函數(shù),并且返回的是一個promise(當然也可以是值,resloved defer)。
4.resolve中加載service
resolve中加載services,但是請求都是異步的,返回的順序不是按照順序來的。在currentBook中需要調(diào)用booksService里面的getBookById()方法。這個時候雖然在load里面已經(jīng)加載dataService.js,但是在currentBook中是無法使用getBookById()方法,所以在currentBook對象中,所以必須重新加載booksService.js。這個時候就需要$injector中的get()方法。$injector
上述就是小編為大家分享的ocLazyLoad和resolve怎么在ui-router中使用了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注創(chuàng)新互聯(lián)成都網(wǎng)站設計公司行業(yè)資訊頻道。
另外有需要云服務器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。