angular中实现控制器之间传递参数的方式
发布时间 - 2026-01-11 00:48:29 点击率:次在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参数,表示事件,有如下方法:
- event.targetScope 获取传播事件的作用域
- event.currentScope 获取接收事件的作用域
- event.name 传播的事件的名称
- event.stopPropagation() 阻止事件进行冒泡传播,仅在$emit事件中有效
- event.preventDefault() 阻止传播事件的发生
- 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父子控制器
# 器中
# 是一个
# 回调
# 就可以
# 自己的
# 会有
# 还没
# 太多
# 也会
# 在这个
# 将会
# 找不到
# 中有
# 会在
# 才可以
# 考虑到
# 这个时候
# 只需要
# 可以使用
# 可通过
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Android实现代码画虚线边框背景效果
Laravel如何处理JSON字段_Eloquent原生JSON字段类型操作教程
再谈Python中的字符串与字符编码(推荐)
Internet Explorer官网直接进入 IE浏览器在线体验版网址
制作企业网站建设方案,怎样建设一个公司网站?
如何用VPS主机快速搭建个人网站?
如何在宝塔面板中创建新站点?
齐河建站公司:营销型网站建设与SEO优化双核驱动策略
音乐网站服务器如何优化API响应速度?
油猴 教程,油猴搜脚本为什么会网页无法显示?
laravel怎么为应用开启和关闭维护模式_laravel应用维护模式开启与关闭方法
如何在景安云服务器上绑定域名并配置虚拟主机?
专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?
Laravel如何实现邮箱地址验证功能_Laravel邮件验证流程与配置
如何用wdcp快速搭建高效网站?
EditPlus中的正则表达式实战(6)
Laravel PHP版本要求一览_Laravel各版本环境要求对照
JavaScript中的标签模板是什么_它如何扩展字符串功能
详解阿里云nginx服务器多站点的配置
Laravel如何将应用部署到生产服务器_Laravel生产环境部署流程
SQL查询语句优化的实用方法总结
如何确保西部建站助手FTP传输的安全性?
java ZXing生成二维码及条码实例分享
黑客入侵网站服务器的常见手法有哪些?
标题:Vue + Vuex 项目中正确使用 JWT 进行身份认证的实践指南
Laravel Sail是什么_基于Docker的Laravel本地开发环境Sail入门
网站制作企业,网站的banner和导航栏是指什么?
矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?
悟空识字如何进行跟读录音_悟空识字开启麦克风权限与录音
html5的keygen标签为什么废弃_替代方案说明【解答】
网站页面设计需要考虑到这些问题
微信h5制作网站有哪些,免费微信H5页面制作工具?
南京网站制作费用,南京远驱官方网站?
Android中Textview和图片同行显示(文字超出用省略号,图片自动靠右边)
成都品牌网站制作公司,成都营业执照年报网上怎么办理?
高端建站如何打造兼具美学与转化的品牌官网?
laravel怎么实现图片的压缩和裁剪_laravel图片压缩与裁剪方法
浅谈javascript alert和confirm的美化
网站建设整体流程解析,建站其实很容易!
Laravel事件监听器怎么写_Laravel Event和Listener使用教程
图册素材网站设计制作软件,图册的导出方式有几种?
如何快速搭建高效可靠的建站解决方案?
如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?
韩国网站服务器搭建指南:VPS选购、域名解析与DNS配置推荐
Laravel模型关联查询教程_Laravel Eloquent一对多关联写法
Laravel如何实现多级无限分类_Laravel递归模型关联与树状数据输出【方法】
如何在腾讯云免费申请建站?
如何用PHP工具快速搭建高效网站?
JavaScript数据类型有哪些_如何准确判断一个变量的类型
如何挑选高效建站主机与优质域名?

