Angular2实现组件交互的方法分析


Posted in Javascript onDecember 19, 2017

本文实例讲述了Angular2实现组件交互的方法。分享给大家供大家参考,具体如下:

前言

在Angular开发中,我们经常会涉及到组件之间的交互,比如会引用自己部门开发的组件
有时候,我们需要向引用的组件里面绑定一些数据,或者我们需要引用的子组件输出一些数据
这时,我们就需要处理好组件之间的交互

组件交互的关键代码

父组件绑定数据到子组件

子组件

<h3>{{hero.name}} says:</h3>
@Input() hero: Hero;

父组件

<hero-child [hero]="myhero" ></hero-child>
myhero = "Mr.IQ";

这里子组件的@Input表示它需要hero这个实体,之后父组件引入子组件的时候,就得在子组件标签内写入hero,同时在自己的组件内为hero赋值就实现了父组件数据绑定到子组件

父组件监听子组件的事件

子组件

<button (click)="vote(true)" >Agree</button>
@Output() onVoted = new EventEmitter<boolean>();
vote(agreed: boolean) { this.onVoted.emit(agreed);}

父组件

<my-voter (myonVoted)="onVoted($event)"></my-voter>
myonVoted(agreed: boolean) { agreed ? this.agreed++ : this.disagreed++; }

子组件的@Output表示它会用onVoted方法向父组件传递一个boolean值,父组件引入子组件之后,通过把子组件的方法绑定到自己的方法上,就可以达到监听子组件的效果

setter截听输入属性值的变化

子组件

<h3>"{{name}}"</h3>
private _name = '';
@Input()
set name(name: string) { this._name = (name && name.trim()) || '<no name set>'; }
get name(): string { return this._name; }

父组件

<name-child [name]="myname"></name-child>

父组件引用子组件之后,向子组件绑定数据,子组件通过set,get对父组件传过来的数据进行修改显示

父组件与子组件通过本地变量互动

子组件

seconds = 11;
stop() { this.message = `Holding at T-${this.seconds} seconds`;  }

父组件

<button (click)="timer.stop()">Stop</button>
<div class="seconds">{{timer.seconds}}</div>
<countdown-timer #timer></countdown-timer>

子组件定义了变量和方法,父组件引用子组件标签之后,通过在标签建立本地变量来代表子组件,然后通过变量就可以实现访问子组件的变量和方法

小结

组件交互是经常用到的知识,需要熟练掌握
还有其它交互方式,比如生命周期、服务,遇到了可以继续深入研究

希望本文所述对大家AngularJS程序设计有所帮助。

Javascript 相关文章推荐
js原型继承的两种方法对比介绍
Mar 30 Javascript
分享33个jQuery与CSS3实现的绚丽鼠标悬停效果
Dec 15 Javascript
使用AngularJS处理单选框和复选框的简单方法
Jun 19 Javascript
自己动手写的javascript前端等待控件
Oct 30 Javascript
在AngularJS中使用jQuery的zTree插件的方法
Apr 21 Javascript
JS和canvas实现俄罗斯方块
Mar 14 Javascript
详解AngularJS 路由 resolve用法
Apr 24 Javascript
javascript帧动画(实例讲解)
Sep 02 Javascript
详解javascript appendChild()的完整功能
Aug 18 Javascript
详解vue 不同环境配置不同的打包命令
Apr 07 Javascript
Websocket 向指定用户发消息的方法
Jan 09 Javascript
手把手教你从零开始react+antd搭建项目
Jun 03 Javascript
JS+WCF实现进度条实时监测数据加载量的方法详解
Dec 19 #Javascript
jquery自定义显示消息数量
Dec 19 #jQuery
基于Vue开发数字输入框组件
Dec 19 #Javascript
jquery实现侧边栏左右伸缩效果的示例
Dec 19 #jQuery
从setTimeout看js函数执行过程
Dec 19 #Javascript
mongoose更新对象的两种方法示例比较
Dec 19 #Javascript
jquery中done和then的区别(详解)
Dec 19 #jQuery
You might like
树型结构列出指定目录里所有文件的PHP类
2006/10/09 PHP
php执行sql语句的写法
2009/03/10 PHP
PHP获取数组中某元素的位置及array_keys函数应用
2013/01/29 PHP
php错误级别的设置方法
2013/06/17 PHP
PHP异常Parse error: syntax error, unexpected T_VAR错误解决方法
2014/05/06 PHP
php伪静态之APACHE篇
2014/06/02 PHP
PHP巧妙利用位运算实现网站权限管理的方法
2017/03/12 PHP
php实现微信分享朋友链接功能
2019/02/18 PHP
php+mysql开发中的经验与常识小结
2019/03/25 PHP
jquery ready()的几种实现方法小结
2010/06/18 Javascript
javascript当中的代码嗅探扩展原生对象和原型(prototype)
2013/01/11 Javascript
浅析用prototype定义自己的方法
2013/11/14 Javascript
js对象转json数组的简单实现案例
2014/02/28 Javascript
Javascript中的return作用及javascript return关键字用法详解
2015/11/05 Javascript
jquery+json实现数据二级联动的方法
2015/11/28 Javascript
简单实现js页面切换功能
2021/01/10 Javascript
JS框架之vue.js(深入三:组件1)
2016/09/29 Javascript
javascript 动态样式添加的简单实现
2016/10/11 Javascript
JS函数修改html的元素内容,及修改属性内容的方法
2016/10/28 Javascript
Bootstrap 3浏览器兼容性问题及解决方案
2017/04/11 Javascript
5分钟教你用nodeJS手写一个mock数据服务器的方法
2019/09/10 NodeJs
layer iframe 设置关闭按钮的方法
2019/09/12 Javascript
[36:33]完美世界DOTA2联赛循环赛 Matador vs Forest 第一场 11.06
2020/11/06 DOTA
Python使用Flask框架获取当前查询参数的方法
2015/03/21 Python
python采用django框架实现支付宝即时到帐接口
2016/05/17 Python
如何基于Python制作有道翻译小工具
2019/12/16 Python
Europcar澳大利亚官网:全球汽车租赁领域的领导者
2019/03/24 全球购物
Mamaearth官方网站:印度母婴护理产品公司
2019/10/06 全球购物
物流创业计划书
2014/02/01 职场文书
班级学习计划书
2014/04/27 职场文书
园艺师求职信
2014/04/27 职场文书
2015年前台文员工作总结
2015/05/18 职场文书
六一儿童节园长致辞
2015/07/31 职场文书
七年级作文之环保作文
2019/10/17 职场文书
Java中CyclicBarrier和CountDownLatch的用法与区别
2021/08/23 Java/Android
详解Python+OpenCV绘制灰度直方图
2022/03/22 Python