欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

ui-router中使用ocLazyLoad和resolve的具體方法

 更新時間:2017年10月18日 11:31:52   作者:快樂八哥  
這篇文章主要介紹了ui-router中使用ocLazyLoad和resolve的具體方法,詳細的介紹了ocLazyLoad和resolve的具體用法,非常具有實用價值,需要的朋友可以參考下

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來進行安裝

<script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.3.0/angular.min.js"></script>
<script src="libs/angular-ui-router/angular-ui-router.js"></script>
<script src="libs/ocLazyLoad/ocLazyLoad.js"></script>

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

5.圖書列表和詳細頁demo

6.參考網(wǎng)址

ocLazyLoad

ui-router中resolve屬性

綜合示例:http://www.dbjr.com.cn/article/92624.htm

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • 強大的 Angular 表單驗證功能詳細介紹

    強大的 Angular 表單驗證功能詳細介紹

    本篇文章主要介紹了強大的 Angular 表單驗證功能詳細介紹,使用 Angular 的內(nèi)置表單校驗能夠完成絕大多數(shù)的業(yè)務場景的校驗需求,有興趣的可以了解一下
    2017-05-05
  • 如何使用angularJs

    如何使用angularJs

    本篇文章主要介紹了一些AngularJs常用的一些屬性和方法,具有很好的參考價值。下面跟著小編一起來看下吧
    2017-05-05
  • Angular中使用ng-zorro圖標庫部分圖標不能正常顯示問題

    Angular中使用ng-zorro圖標庫部分圖標不能正常顯示問題

    這篇文章主要介紹了Angular中使用ng-zorro圖標庫部分圖標不能正常顯示問題,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-04-04
  • Angular模板表單校驗方法詳解

    Angular模板表單校驗方法詳解

    這篇文章主要為大家詳細介紹了Angular模板表單校驗方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • angular8和ngrx8結(jié)合使用的步驟介紹

    angular8和ngrx8結(jié)合使用的步驟介紹

    這篇文章主要給大家介紹了關于angular8和ngrx8結(jié)合使用的詳細步驟,文中通過示例代碼介紹的非常詳細,對大家學習或者使用angular8具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-12-12
  • AngularJS 驗證碼60秒倒計時功能的實現(xiàn)

    AngularJS 驗證碼60秒倒計時功能的實現(xiàn)

    最近在做AngularJS 項目,這是寫的一個60秒倒計時功能,下面小編給大家介紹AngularJS 驗證碼60秒倒計時功能的實現(xiàn),需要的朋友參考下吧
    2017-06-06
  • AngularJS實現(xiàn)的簡單拖拽功能示例

    AngularJS實現(xiàn)的簡單拖拽功能示例

    這篇文章主要介紹了AngularJS實現(xiàn)的簡單拖拽功能,涉及AngularJS事件響應及頁面元素屬性動態(tài)操作相關實現(xiàn)技巧,需要的朋友可以參考下
    2018-01-01
  • Angular懶加載機制刷新后無法回退的快速解決方法

    Angular懶加載機制刷新后無法回退的快速解決方法

    使用oclazyload懶加載angular的模塊,刷新頁面后,單擊回退按鈕無法返回上一個頁面.怎么回事呢?下面小編給大家?guī)砹薬ngular懶加載機制刷新后無法回退的快速解決方法,非常不錯,感興趣的朋友參考下
    2016-08-08
  • AngularJS語法詳解

    AngularJS語法詳解

    本文通過示例向大家介紹了AngularJS語法的使用,小伙伴們認真研讀下吧,非常的實用哦。
    2015-01-01
  • 深入理解Angularjs向指令傳遞數(shù)據(jù)雙向綁定機制

    深入理解Angularjs向指令傳遞數(shù)據(jù)雙向綁定機制

    這篇文章主要深入的給大家介紹了Angularjs向指令傳遞數(shù)據(jù),雙向綁定機制的相關資料,需要的朋友可以參考下
    2016-12-12

最新評論