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

溫馨提示×

溫馨提示×

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

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

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

石棉县| 会宁县| 玉屏| 华安县| 新干县| 乐平市| 治县。| 逊克县| 瑞安市| 赫章县| 武乡县| 惠州市| 庆城县| 正蓝旗| 泰宁县| 长岛县| 景洪市| 建水县| 陈巴尔虎旗| 鹰潭市| 宜丰县| 红原县| 新津县| 汤阴县| 平和县| 卢湾区| 个旧市| 巨野县| 上犹县| 青海省| 宿州市| 新巴尔虎左旗| 平潭县| 海原县| 米易县| 枣阳市| 隆尧县| 镇平县| 琼结县| 高邮市| 新余市|