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: 发射(只能向上)

如果控制器向同级传值: 可以通过向上发射,然后再向下广播回来

results matching ""

    No results matching ""