全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

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

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

1.通过$rootscope传参

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

<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)子向父控制器传值

<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)父向子控制器传值

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中服务是一个单例,所以在服务中生成一个对象,该对象就可以利用依赖注入的方式在所有的控制器共享。

例:

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中也会得到修改过后的值。

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


# angularjs控制器参数  # angularjs 控制器传值  # angularjs父子控制器  # 器中  # 是一个  # 回调  # 就可以  # 自己的  # 会有  # 还没  # 太多  # 也会  # 在这个  # 将会  # 找不到  # 中有  # 会在  # 才可以  # 考虑到  # 这个时候  # 只需要  # 可以使用  # 可通过 


相关文章: 网站企业制作流程,用什么语言做企业网站比较好?  建站之星24小时客服电话如何获取?  如何制作网站标识牌,动态网站如何制作(教程)?  如何基于云服务器快速搭建网站及云盘系统?  东莞市网站制作公司有哪些,东莞找工作用什么网站好?  如何快速搭建安全的FTP站点?  如何快速生成高效建站系统源代码?  Python路径拼接规范_跨平台处理说明【指导】  建站之星展会模板:智能建站与自助搭建高效解决方案  教学论文网站制作软件有哪些,写论文用什么软件 ?  如何通过智能用户系统一键生成高效建站方案?  建站之星安装需要哪些步骤及注意事项?  如何通过宝塔面板实现本地网站访问?  如何零成本快速生成个人自助网站?  定制建站价位费用解析与套餐推荐全攻略  ,巨量百应是干嘛的?  如何快速搭建高效可靠的建站解决方案?  如何在香港免费服务器上快速搭建网站?  如何通过老薛主机一键快速建站?  ,网站推广常用方法?  矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?  如何通过网站建站时间优化SEO与用户体验?  如何高效完成独享虚拟主机建站?  制作网站的软件免费下载,免费制作app哪个平台好?  网站制作多少钱一个,建一个论坛网站大约需要多少钱?  表情包在线制作网站免费,表情包怎么弄?  如何在宝塔面板创建新站点?  购物网站制作公司有哪些,哪个购物网站比较好?  建站主机解析:虚拟主机配置与服务器选择指南  ,购物网站怎么盈利呢?  如何制作算命网站,怎么注册算命网站?  家庭建站与云服务器建站,如何选择更优?  专业网站制作服务公司,有哪些网站可以免费发布招聘信息?  如何快速搭建二级域名独立网站?  建站主机选购指南:核心配置优化与品牌推荐方案  制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?  如何通过PHP快速构建高效问答网站功能?  公司网站制作费用多少,为公司建立一个网站需要哪些费用?  专业商城网站制作公司有哪些,pi商城官网是哪个?  网站制作需要会哪些技术,建立一个网站要花费多少?  PHP 500报错的快速解决方法  广州建站公司哪家好?十大优质服务商推荐  网站设计制作企业有哪些,抖音官网主页怎么设置?  东莞专业网站制作公司有哪些,东莞招聘网站哪个好?  如何在云指建站中生成FTP站点?  香港服务器如何优化才能显著提升网站加载速度?  建站主机是什么?如何选择适合的建站主机?  车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?  高性价比服务器租赁——企业级配置与24小时运维服务  建站VPS配置与SEO优化指南:关键词排名提升策略 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。