国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

AngularJS中的按需加載ocLazyLoad示例

2019-11-19 18:00:15
字體:
來源:轉載
供稿:網友

一、前言

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*/<h1>hi i am hzp </h1>  <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模塊

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 临西县| 达日县| 宁阳县| 越西县| 磐石市| 南陵县| 麟游县| 疏勒县| 邹平县| 民乐县| 柘荣县| 天峻县| 凯里市| 尚志市| 上饶市| 灌南县| 从江县| 长葛市| 崇明县| 西贡区| 辛集市| 叶城县| 南丰县| 普兰县| 蒙城县| 图们市| 永平县| 白城市| 伊川县| 开封市| 马鞍山市| 会泽县| 合山市| 三台县| 揭东县| 胶州市| 高州市| 广饶县| 张家界市| 尉犁县| 城步|