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 相关文章推荐
12款经典的白富美型—jquery图片轮播插件—前端开发必备
Jan 08 Javascript
在JavaScript中实现类的方式探讨
Aug 28 Javascript
js触发select onchange事件的小技巧
Aug 05 Javascript
js实现当前输入框高亮显示的方法
Aug 19 Javascript
js实现敏感词过滤算法及实现逻辑
Jul 24 Javascript
解决vue同一slot在组件中渲染多次的问题
Sep 06 Javascript
如何在基于vue-cli的项目自定义打包环境
Nov 10 Javascript
javascript实现动态时钟的启动和停止
Jul 29 Javascript
纯 JS 实现放大缩小拖拽功能(完整代码)
Nov 25 Javascript
JS获取当前时间的年月日时分秒及时间的格式化的方法
Dec 18 Javascript
vue2和vue3的v-if与v-for优先级对比学习
Oct 10 Javascript
使用TS来编写express服务器的方法步骤
Oct 29 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实时显示输出
2008/10/02 PHP
php倒计时出现-0情况的解决方法
2016/07/28 PHP
PHP基于GD库的图像处理方法小结
2016/09/27 PHP
通过修改Laravel Auth使用salt和password进行认证用户详解
2017/08/17 PHP
Use Word to Search for Files
2007/06/15 Javascript
JavaScript 应用技巧集合[推荐]
2009/08/30 Javascript
你未必知道的JavaScript和CSS交互的5种方法
2014/04/02 Javascript
javascript 处理null及null值示例
2014/06/09 Javascript
js设置cookie过期当前时间减去一秒相当于立即过期
2014/09/04 Javascript
JavaScript中Object.prototype.toString方法的原理
2016/02/24 Javascript
Javascript之Number对象介绍
2016/06/07 Javascript
Javascript中字符串相关常用的使用方法总结
2017/03/13 Javascript
JS正则表达式判断有效数实例代码
2017/03/13 Javascript
vue2 自定义动态组件所遇到的问题
2017/06/08 Javascript
bootstrap3-dialog-master模态框使用详解
2017/08/22 Javascript
vue中实现滚动加载更多的示例
2017/11/08 Javascript
基于vue.js无缝滚动效果
2018/01/25 Javascript
JavaScript同源策略和跨域访问实例详解
2018/04/03 Javascript
原生JS 实现的input输入时表格过滤操作示例
2019/08/03 Javascript
jQuery实现全选、反选和不选功能的方法详解
2019/12/04 jQuery
小程序跳转H5页面的方法步骤
2020/03/06 Javascript
再也不怕 JavaScript 报错了,怎么看怎么处理都在这儿
2020/12/09 Javascript
python3.3教程之模拟百度登陆代码分享
2014/01/16 Python
Python人脸识别初探
2017/12/21 Python
python脚本实现mp4中的音频提取并保存在原目录
2020/02/27 Python
Python定义一个Actor任务
2020/07/29 Python
python中uuid模块实例浅析
2020/12/29 Python
selenium携带cookies模拟登陆CSDN的实现
2021/01/19 Python
请问如下代码执行后a和b的值分别是什么
2016/05/05 面试题
python re模块和正则表达式
2021/03/24 Python
给医务人员表扬信
2014/01/12 职场文书
婚庆公司的创业计划书
2014/01/22 职场文书
经销商会议开幕词
2016/03/04 职场文书
MySQL库表名大小写的选择
2021/06/05 MySQL
Redis+Lua脚本实现计数器接口防刷功能(升级版)
2022/02/12 Redis
Python线程池与GIL全局锁实现抽奖小案例
2022/04/13 Python