亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

AngularJS中的按需加載ocLazyLoad示例

發布時間:2020-10-15 19:27:05 來源:腳本之家 閱讀:131 作者:BestMe丶 欄目:web開發

一、前言

ocLoayLoad是AngularJS的模塊按需加載器。一般在小型項目里,首次加載頁面就下載好所有的資源沒有什么大問題。但是當我們的網站漸漸龐大起來,這樣子的加載策略讓網速初始化速度變得越來越慢,用戶體驗不好。二來,分模塊加載易于團隊協作,減低代碼沖突。

二、按需加載的對象

各個Controller模塊、Directive模塊、Server模塊、template模板,其實這些都是一些 .js文件或者 .html文件 。

三 、按需加載的場景

1 路由加載(resolve/uiRouter)

基于uiRouter的resolve是在加載controller和template之前所執行的一系列操作,它幫助我們初始化我們所要前往的那一個視圖。只有be solved(操作完成),controller才會被實例化。因此,我們可以在resolve步驟里面加載我們所需要的controller。

  $stateProvider
    .state('index', {
      url: '/',
      views: {
        'lazyLoadView': {
          templateUrl: 'partials/main.html',
          controller: 'AppCtrl'
        }  
      },
      resolve: {
        loadMyCtrl: ['$ocLazyLoad', function($ocLazyLoad){
          return $ocLazyLoad.load('js/AppCtrl.js')
        }]
      }
    })

其中,'js/AppCtrl.js'里面放著一個我們所需要的controller

angular.module('myApp')
.controller('AppCtrl', ['$scope', function($scope){
//...
}])

2 依賴加載

在依賴項里面導入我們所需要的一系列模塊(這里有一層'[ ]'符合哦)

angular.module('gridModule', [[
  'bower_components/angular-ui-grid/ui-grid.js',
  'bower_components/angular-ui-grid/ui-grid.css'
]]).controller('GridModuleCtrl', ['$scope', function($scope){
  //...
}])

3 Cotroller里動態加載

angular.module('myApp')
.controller('AppCtrl', ['$scope','$ocLazyLoad', function($scope, $ocLazyLoad){
  $scope.loadBootstrap = function(){
    $ocLazyLoad.load([
     'bower_components/bootstrap/dist/js/bootstrap.js',
     'bower_components/bootstrap/dist/css/bootstrap.css'
    ])
  }
  var unbind = $scope.$on('ocLazyLoad.fileLoaded', function(e, file){
    $scope.bootstrapLoaded = true;
     console.log('下載boot完成');
     unbind();
  })
}])

4 template包含加載(config)

如何處理我們所加載的html模板里面嵌套的controller呢?這里需要oc-lazy-load指令和$ocLazyLoadProvider的配置

/*template A.html*/
<h2>hi i am hzp </h2>
  <div oc-lazy-load="gridModule">
    <div ng-controller="GridModuleCtrl">
      <span>{{test}}</span><br/>
      <div ui-grid="gridOptions" class="gridStyle"></div>
    </div>
  </div>
</div>


  $ocLazyLoadProvider.config({
    modules: [{
      name: 'gridModule',
      files: [
        'js/gridModule.js'
      ]
    }]
  })

四、如何組織按需加載

分路由、按功能來區分、打包成不同的多個或單個controller.directive.server模塊

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

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

AI

丽水市| 尤溪县| 宁晋县| 麻江县| 江口县| 仁化县| 化德县| 湾仔区| 淳化县| 阜南县| 洛川县| 阿拉善左旗| 会宁县| 鄄城县| 皋兰县| 武乡县| 林州市| 惠来县| 凤山县| 福泉市| 腾冲县| 北京市| 霍城县| 张掖市| 乃东县| 湖南省| 宜丰县| 兴城市| 广西| 黔西县| 桐柏县| 五大连池市| 建湖县| 建昌县| 紫阳县| 绵阳市| 林口县| 洱源县| 祁东县| 玉门市| 行唐县|