91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

ocLazyLoad和resolve怎么在ui-router中使用

發布時間:2021-03-30 16:08:43 來源:億速云 閱讀:162 作者:Leah 欄目:web開發

這期內容當中小編將會給大家帶來有關ocLazyLoad和resolve怎么在ui-router中使用,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

1.AngularJS按需加載

AngularJS主要應用開發SPA(Single Page Application)項目,所以在小型項目中,services、filters和controllers都在index.html中加載。Google給的AngularJS官方的angular-seed和angular-phonecat都是這樣。

對于復雜一點,大型的項目,如果所有的內容一開始就加載,對首頁的性能影響比較大,即使靜態javascript文件使用CDN,對性能還是有很大的影響。所有需要引入按需加載機制,而Angular1.x版本中,ocLazyLoad是一個不錯的按鈕加載解決方案。

2.ocLazyLoad的功能

ocLazyLoad: your solution for lazy loading with Angular 1.x

入門可以參照:ocLazyLoad快速入門,代碼也非常簡單:

1.引入ocLazyLoad文件,可以使用npm和bower來進行安裝

<script src="//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配置參數中,是一個對象(key-value),每一個value都是一個可以依賴注入的函數,并且返回的是一個promise(當然也可以是值,resloved defer)。

4.resolve中加載service

resolve中加載services,但是請求都是異步的,返回的順序不是按照順序來的。在currentBook中需要調用booksService里面的getBookById()方法。這個時候雖然在load里面已經加載dataService.js,但是在currentBook中是無法使用getBookById()方法,所以在currentBook對象中,所以必須重新加載booksService.js。這個時候就需要$injector中的get()方法。$injector

上述就是小編為大家分享的ocLazyLoad和resolve怎么在ui-router中使用了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

盘山县| 新营市| 新乡市| 青冈县| 洞口县| 曲麻莱县| 延吉市| 米林县| 南华县| 平昌县| 家居| 应城市| 调兵山市| 万盛区| 牡丹江市| 县级市| 赣榆县| 乌鲁木齐市| 衡南县| 海晏县| 灵寿县| 台州市| 乾安县| 宣城市| 池州市| 沽源县| 张北县| 武安市| 元谋县| 安远县| 海林市| 安庆市| 渑池县| 伊金霍洛旗| 霍林郭勒市| 丰镇市| 陇西县| 邵东县| 哈巴河县| 泸州市| 周宁县|