中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

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

海林市| 石河子市| 繁昌县| 达尔| 唐河县| 台安县| 无极县| 齐齐哈尔市| 郓城县| 丰顺县| 孝昌县| 桐乡市| 扎赉特旗| 夏邑县| 九寨沟县| 两当县| 北京市| 彭水| 定安县| 巧家县| 三门县| 建瓯市| 依兰县| 峨边| 邢台县| 德化县| 平乐县| 称多县| 达拉特旗| 浦县| 桃江县| 共和县| 东乡| 正蓝旗| 嵊州市| 洪泽县| 灌南县| 东海县| 启东市| 通化县| 河间市|