angular的继承作用域通信
本人学了一段时间的angular,angular之间怎样通信,我就总结以下几点,如果有哪位大神认为不对,敬请赐教。
1、父子之间的作用域进行通信
html
<div ng-controller="Parent">
{{name}} //Parent
<div ng-controller="child">
{{name}} //Parent
</div>
</div>
js
m1.controller("Parent",["$scope",function($scope){
$scope.name = "Parent";
}])
m1.controller("child",["$scope",function($scope){
}])
2、$rootScope 挂在全局作用域上,适用范围更广
html
<div ng-controller="myCtrl">
{{name}} //Parent
<div ng-controller="Parent">
{{name}} //Parent
<div ng-controller="child">
{{name}} //Parent
</div>
</div>
</div>
js
m1.controller("Parent",["$scope","$rootScope",function($scope,$rootScope){
$scope.name = "Parent";
$rootScope.name = $scope.name;
}])
m1.controller("child",["$scope",function($scope){
}])
3、基于事件的数据传递 组件 webcomponent
html
<div ng-controller="Parent">
<input type="text" ng-model="name" ng-change="change()">
<div ng-controller="child">
<input type="text" ng-model="name" ng-change="change()">
</div>
<div ng-controller="secChild">
<input type="text" ng-model="name">
</div>
</div>
js
m1.controller("Parent",["$scope","$rootScope",function($scope,$rootScope){
// 监听 发送消息 $emit
$scope.$on("changeName",function(event,data){
console.log(data);
//$broadcast 广播 广播只有子级和自己知道,父级(就是Parent更上级)不知道
$scope.$broadcast("sendName",data);
})
//监听 $broadcast 广播发送的消息
$scope.$on("sendName",function(event,data){
console.log(data);
$scope.name = data;
})
}])
m1.controller("child",["$scope",function($scope){
$scope.name = "第一个孩子";
$scope.change = function(){
//$emit 发送 只能发送自己的父级
$scope.$emit("changeName","发送-》广播");
}
//监听 $broadcast 广播发送的消息
$scope.$on("sendName",function(event,data){
console.log(data);
$scope.name = data;
})
}])
m1.controller("secChild",["$scope",function($scope){
$scope.name = "第二个孩子";
//监听 $broadcast 广播发送的消息
$scope.$on("sendName",function(event,data){
console.log(data);
$scope.name = data;
})
}])
总结:$emit 发送消息,只能发送给自己的父级或者更上级(如:爷爷级),使用监听($on(监听的名字,function(event,data){ }))就能收到,自己以及自己的子级都不能发送;
$broadcast 广播消息 ,只能被自己或是自己的子级所监听($on(监听的名字,function(event,data){ }))的到,父级或者更上级不能监听的到
4、service 没有作用域的概念
html
<body ng-controller="myCtrl">
<input type="text" ng-model="name" >
<div ng-controller="Parent">
<input type="text" ng-model="name" >
<div ng-controller="child">
<input type="text" ng-model="name" ng-change="change()">
</div>
<div ng-controller="secChild">
<input type="text" ng-model="name">
</div>
</div>
</body>
js
m1.controller("Parent",["$scope","$rootScope",function($scope,$rootScope){
}])
m1.controller("child",["$scope","myData",function($scope,myData){
//为什么 $scope.name = myData.name; 不能使上面的联动改变呢
//据我所知,我觉得 上面的 $scope.name 是赋值,物理地址也是一样的,就算html中<input>标签都有里面 ng-model="name",
//这样是不会联动的,也就是说多个controller里面的物理地址不一样,
//如果是引用myData,$scope.data = myData; html中<input>标签都有里面 ng-model="name",只是引用其中的数据,其他
//包括物理地址都不变,这样就可以联动
$scope.data = myData;
}])
m1.controller("secChild",["$scope","myData",function($scope,myData){
//为什么 $scope.name = myData.name; 不能使上面的联动改变呢
$scope.data = myData;
}])
m1.factory("myData",function(){
return{
name : "123"
}
})
总结:service与$emit、$broadcast、$on的区别,service没有作用域的概念;$emit、$broadcast、$on必须要清楚父子级以及作用域的范围。
angular的继承作用域通信的更多相关文章
- 跟我学AngularJs:Controller数据共享、继承、通信使用具体解释
林炳文Evankaka原创作品.转载请注明出处http://blog.csdn.net/evankaka 摘要:本文主讲了AngularJs中的Controller中数据共享.继承.通信的具体使用 本 ...
- 38.angular的scope作用域
转自:https://www.cnblogs.com/best/tag/Angular/ 1. Scope(作用域) 是应用在 HTML (视图) 和 JavaScript (控制器)之间的纽带. S ...
- angular组件间的通信(父子、不同组件的数据、方法的传递和调用)
angular组件间的通信(父子.不同组件的数据.方法的传递和调用) 一.不同组件的传值(使用服务解决) 1.创建服务组件 不同组件相互传递,使用服务组件,比较方便,简单,容易.先将公共组件写在服务的 ...
- 作用域通信对象:session用户在登录时通过`void setAttribute(String name,Object value)`方法设置用户名和密码。点击登录按钮后,跳转到另外一个页面显示用户
作用域通信对象:session session对象基于会话,不同用户拥有不同的会话.同一个用户共享session对象的所有属性.作用域开始客户连接到应用程序的某个页面,结束与服务器断开连接.sessi ...
- angular 控制器之间的通信
1, 利用作用域的继承方式 由于作用域的继承是基于js的原型继承方式,所以这里分为两种情况,当作用域上面的值为基本类型的时候,修改父作用域上面的值会 影响到子作用域,反之,修改子作用域只会影响子作用域 ...
- ionic准备之angular基础——继承(3)
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 后端学 Angular 2 —— 组件间通信
1. 父组件向子组件传递信息 使用@Input 子组件的属性用 @Input 进行修饰,在父组件的模板中绑定变量 例子: import { Component, OnInit, Input } fro ...
- javascript构造函数+原形继承+作用域扩充
目前为止我认为这是最佳的声明对象的模式,将今天学到的东西写下 <script type="text/javascript"> function Constructor( ...
- angular.js之作用域scope'@','=','&'
<!doctype html> <html ng-app='myApp'> <head> </head> <body> <script ...
随机推荐
- 远程调用与编译DS作业
1.编译服务器上的ds作业 dscc /d 服务器地址:端口 /u 用户名 /p 密码 工程名称 /J 作业名称 解释: 作业名称:直接写作业名称即可,不用.pjb 2.执行服务器上的ds作业 dsj ...
- Python中的单例设计模式
1)设计模式: 是前人工作的总结和提炼.通常,被人们广泛流传的设计模式. 某一问题的特定解决方案,使用设计模式是为了可重用代码,是代码更容易被人理解, 增加代码的可用性. 2)单例设计模式: ...
- JQ上传预览+存数据库
因为之前老师讲的方法有不少BUG 现在经过完善已经修复 之前老是讲的方法是每一张都会被传到后台文件夹里面去 导致在预览过程中如果刷新页面 那么预览的图片不能从后台文件夹中删除 这个方法实现在本地预览 ...
- python_安装第三方库
1.有一个专门可下载安装第三方库的网址: http://www.lfd.uci.edu/~gohlke/pythonlibs/ Ctrl+f 搜索要下载的第三方库,并下载 2.库文件都是以 whl ...
- (转)Mahout Kmeans Clustering 学习
一.Mahout命令使用 合成控制的数据集 synthetic_control.data 可以从 此处下载,总共由600行X60列double型的数据组成, 意思是有600个元组,每个元组是一个时间序 ...
- React之setState()
我们知道,在react中更新单个组件下state中的数据可以用setState()函数来实现,并且可以通过两种传参方式:对象.函数. 另外从文档中我们也可以了解到react可以将多个setState( ...
- EasyRMS录播管理服务器项目实战:windows上开机自启动NodeJS服务
本文转自EasyDarwin开源团队成员Penggy的博客:http://www.jianshu.com/p/ef840505ae06 近期在EasyDarwin开源团队开发一款基于EasyDarwi ...
- Mininet python代码创建拓扑、交互式界面创建主机、交换机
python代码创建拓扑: from mininet.net importMininet net =Mininet() # Creating nodes in the network. c ...
- .NET Web开发技术简单整理 转
.NET Web开发技术简单整理 原文:http://www.cnblogs.com/SanMaoSpace/p/3157293.html 在最初学习一些编程语言.一些编程技术的时候,做的更多的是如何 ...
- OK335x mksd.sh hacking
#! /bin/sh # mk3PartSDCard. # Licensed under terms of GPLv2 # 参考文档: # . sfidsk创建可启动分区问题 # http://seg ...