AngularJs
angular.module()参数说明
- 注册一个模块
var myApp = angular.module('myApp', [
'ui.router',
'oc.lazyLoad',
'ngAnimate',
'ngResource',
'ngCookies',
'ui.bootstrap',
'ui.tree',
'pascalprecht.translate'
]);
var myApp = angular.module('myApp',[]);
angular.module方法有两个参数:模板名称、依赖注入列表(为空则不需要依赖关系)。
- 获取一个模板
var myApp = angular.module('myApp');
如果应用程序中已经有了这个模板,那么就返回和这个模板一样配置的模板;
如果应用程序中不存在,会抛出异常。
run方法及config方法
myApp
.run(
['$rootScope', '$state', '$stateParams',
function ($rootScope, $state, $stateParams) {
$rootScope.$state = $state;
$rootScope.$stateParams = $stateParams;
}
]
)
myApp
.config(['$stateProvider', '$urlRouterProvider', '$ocLazyLoadProvider', '$locationProvider',
function ($stateProvider, $urlRouterProvider, $ocLazyLoadProvider, $locationProvider) {
$urlRouterProvider.otherwise('/account');
$stateProvider
// 概览
.state('overview', {
url: '/overview',
templateUrl: '../tpls/overview.html'
// resolve: {
// deps: ['$ocLazyLoad', function( $ocLazyLoad ){
// return $ocLazyLoad.load(
// 'js/controllers/login.js'
// );
// }]
// }
})
}
])
run方法:最先执行的方法,在angular项目启动时只执行一次,用来定义全局的数据或逻辑
config方法:在模块加载阶段,对模块进行自定义配置
- 区别
- config先执行,run后执行,ng启动阶段:config-->run-->compile/link
注入服务类型不同
config里允许注入的是provider和constance(常量),run里允许注入的是provider和constant,还可以是factory, service, value
Angularjs控制器传参问题
broadcast: 广播(只能向下)
emit: 发射(只能向上)
如果控制器向同级传值: 可以通过向上发射,然后再向下广播回来