在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)子向父控制器传值
<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父子控制器
# 器中
# 是一个
# 回调
# 就可以
# 自己的
# 会有
# 还没
# 太多
# 也会
# 在这个
# 将会
# 找不到
# 中有
# 会在
# 才可以
# 考虑到
# 这个时候
# 只需要
# 可以使用
# 可通过
相关文章:
简单实现Android文件上传
大连企业网站制作公司,大连2025企业社保缴费网上缴费流程?
家具网站制作软件,家具厂怎么跑业务?
深圳网站制作平台,深圳市做网站好的公司有哪些?
攀枝花网站建设,攀枝花营业执照网上怎么年审?
如何快速搭建二级域名独立网站?
建站主机服务器选型指南与性能优化方案解析
香港服务器选型指南:免备案配置与高效建站方案解析
c# await 一个已经完成的Task会发生什么
盘锦网站制作公司,盘锦大洼有多少5G网站?
建站主机核心功能解析:服务器选择与网站搭建流程指南
Android滚轮选择时间控件使用详解
建站之星安装后界面空白如何解决?
如何快速搭建自助建站会员专属系统?
,南京靠谱的征婚网站?
如何通过免费商城建站系统源码自定义网站主题与功能?
红河网站制作公司,红河事业单位身份证如何上传?
小程序网站制作需要准备什么资料,如何制作小程序?
建站之星CMS建站配置指南:模板选择与SEO优化技巧
兔展官网 在线制作,怎样制作微信请帖?
建站之星3.0如何解决常见操作问题?
西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?
MySQL查询结果复制到新表的方法(更新、插入)
深圳 网站制作,深圳招聘网站哪个比较好一点啊?
建站主机选哪家性价比最高?
高防服务器:AI智能防御DDoS攻击与数据安全保障
如何快速搭建高效WAP手机网站吸引移动用户?
网站制作的步骤包括,正确网址格式怎么写?
开源网站制作软件,开源网站什么意思?
官网网站制作腾讯审核要多久,联想路由器newifi官网
如何用搬瓦工VPS快速搭建个人网站?
如何用狗爹虚拟主机快速搭建网站?
如何零基础在云服务器搭建WordPress站点?
如何获取免费开源的自助建站系统源码?
如何通过虚拟主机空间快速建站?
如何在西部数码注册域名并快速搭建网站?
外贸公司网站制作,外贸网站建设一般有哪些步骤?
建站VPS能否同时实现高效与安全翻墙?
北京的网站制作公司有哪些,哪个视频网站最好?
如何高效生成建站之星成品网站源码?
定制建站平台哪家好?企业官网搭建与快速建站方案推荐
如何在景安云服务器上绑定域名并配置虚拟主机?
移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?
移民网站制作流程,怎么看加拿大移民官网?
独立制作一个网站多少钱,建立网站需要花多少钱?
自助网站制作软件,个人如何自助建网站?
网站制作网站,深圳做网站哪家比较好?
建站之星IIS配置教程:代码生成技巧与站点搭建指南
如何在VPS电脑上快速搭建网站?
如何彻底删除建站之星生成的Banner?
*请认真填写需求信息,我们会在24小时内与您取得联系。