angular中实现控制器之间传递参数的方式

本篇文章主要介绍了angular中实现控制器之间传递参数的方式,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。

在angular中,每个controller(控制器)都会有自己的$scope,通过为这个对象添加属性赋值,就可以将数据传递给模板进行渲染,每个$scope只会在自己控制器内起作用,而有时候需要用到其他控制器中的数据,这个时候就要考虑到控制器之间参数的传递了。

1.通过$rootscope传参

首先,在angular中存在作用域的继承,继承作用域符合 JavaScript 的原型继承机制,这意味着如果我们在子作用域中访问一个父作用域中定义的属性,JavaScript 首先在子作用域中寻找该属性,没找到再从原型链上的父作用域中寻找,如果还没找到会再往上一级原型链的父作用域寻找。在 AngularJS 中,作用域原型链的顶端是$rootScope,AnguarJS 将会寻找到$rootScope 为止,如果还是找不到,则会返回 undefined。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<div ng-app= "app" >
     <div ng-controller= "parent" >
       {{name}}
       <div ng-controller= "son" >
       {{name}}
       </div>
     </div>
   </div>
   var app=angular.module( "app" ,[]);
   app.controller( 'parent' , [ '$scope' , function ($scope) {
     $scope.name= "hello" ;
   }]);
   app.controller( 'son' , [ '$scope' , function ($scope) {
     console.log($scope.name); //hello
   }]);

在子控制器中打印name,但我们发现在这个控制器中并未为$scope添加name,于是向父作用域查找,发现父作用域存在该属性,所以可以打印出来。

$rootscope 是所有 $scope 的最上层对象,可以理解为一个 Angular 应用中的全局作用域对象。所以为$rootscope添加的属性,在所有的控制器中都可以访问得到。但是为它附加太多逻辑或者变量并不是一个好主意,和js全局污染是一样的.

2.通过事件的方式

首先介绍一下angular中的事件广播:

$on(name,handler) 注册一个事件处理函数,该函数在特定的事件被当前作用域收到(从父级或者子级作用域)时将被调用。

$emit(name,args) 向当前父作用域发送一个事件,直至根作用域。

$broadcast(name,args) 向当前作用域下的子作用域发送一个事件。

name表示事件名称,args表示事件传播的数据,handler表示在接受到传递时要执行的回调,该回调中有event参数,表示事件,有如下方法:

  1. event.targetScope 获取传播事件的作用域
  2. event.currentScope 获取接收事件的作用域
  3. event.name 传播的事件的名称
  4. event.stopPropagation() 阻止事件进行冒泡传播,仅在$emit事件中有效
  5. event.preventDefault() 阻止传播事件的发生  
  6. event.defaultPrevented 如果调用了preventDefault事件则返回true

1)子向父控制器传值

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
<div ng-app= "app" >
     <div ng-controller= "parent" >
       {{name}}
       <div ng-controller= "son" >
       {{name}}
       </div>
     </div>
   </div>
   var app=angular.module( "app" ,[]);
   app.controller( 'parent' , [ '$scope' , function ($scope) {
     $scope.$on( 'call' , function (event,data){
       $scope.name=data;
       console.log(data);
     });
   }]);
   app.controller( 'son' , [ '$scope' , function ($scope) {
     $scope.name= "hello" ;
     $scope.$emit( 'call' , $scope.name);
   }]);

2)父向子控制器传值

?
1
2
3
4
5
6
7
8
9
10
11
var app=angular.module( "app" ,[]);
   app.controller( 'parent' , [ '$scope' , function ($scope) {
     $scope.name= "hello" ;
     $scope.$broadcast( 'call' , $scope.name); //传值
   }]);
   app.controller( 'son' , [ '$scope' , function ($scope) {
     $scope.$on( 'call' , function (event,data1){
       $scope.name1=data1; //接受值
       
     });
   }]);

注意:参数name相同时,父子控制器之间才可以传值

这种方式不可实现兄弟级传值,不过可以使用父级控制器作为中介,先由子控制器传值给父控制器,然后再由父控制器传递给另外的子控制器。

补充:之前遇到一个需求是,父控制器中,触发change事件后,获取数据传递给子控制,但是在子控制器只需要接受一次,发现可通过如下方式:

var scan=$scope.$on(name,handler);scan();这样子控制器就只接受可一次,避免了多次接受带来的影响!

3.通过服务

在angular中服务是一个单例,所以在服务中生成一个对象,该对象就可以利用依赖注入的方式在所有的控制器中共享。

例:

?
1
2
3
4
5
6
7
8
9
10
var app=angular.module( "app" ,[]);
   app.controller( 'myCtrl' , [ '$scope' , 'appService' , function ($scope,appService) {
     appService.name= "hi!!"
   }]);
   app.controller( 'myCtrl1' , [ '$scope' , 'appService' , function ($scope,appService) {
     $scope.name=appService.name;
   }]);
   app.service( "appService" , [ function (){
     this .name= "hello" ;
   }]);

通过在appService这个服务中添加对象,然后在需要用到的控制器中,通过依赖注入的方式导入该服务,在myCtrl控制器中修改这个对象,在myCtrl1中也会得到修改过后的值。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值