AngularJS主要应用开发SPA(Single Page Application)项目,因此在小型项目中,services、filters和controllers都在index.html中加载。Google给的AngularJS官方的angular-seed和angular-phonecat都是这样。javascript
对于复杂一点,大型的项目,若是全部的内容一开始就加载,对首页的性能影响比较大,即便静态javascript文件使用CDN,对性能仍是有很大的影响。全部须要引入按需加载机制,而Angular1.x版本中,ocLazyLoad是一个不错的按钮加载解决方案。html
ocLazyLoad: your solution for lazy loading with Angular 1.x
入门能够参照:ocLazyLoad快速入门,代码也很是简单:java
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>
var myApp = angular.module("MyApp", ["oc.lazyLoad"]);
myApp.controller("MyCtrl", function($ocLazyLoad) { $ocLazyLoad.load('testModule.js'); });
在实际项目中service和controller文件都是经过ocLazyLoad加载,而且是放在resolve中加载。代码示例以下:git
.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);; }); }] } })
resolve在state配置参数中,是一个对象(key-value),每个value都是一个能够依赖注入的函数,而且返回的是一个promise(固然也能够是值,resloved defer)。angularjs
resolve中加载services,可是请求都是异步的,返回的顺序不是按照顺序来的。在currentBook中须要调用booksService里面的getBookById()方法。这个时候虽然在load里面已经加载dataService.js,可是在currentBook中是没法使用getBookById()方法,因此在currentBook对象中,因此必须从新加载booksService.js。这个时候就须要$injector中的get()方法。$injectorgithub
代码地址:https://github.com/liminjun/ocLazyLoad-resolve-demoajax
ocLazyLoadapi
ui-router中resolve属性promise