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 相关文章推荐
javascript this用法小结
Dec 19 Javascript
javascript 模拟JQuery的Ready方法实现并出现的问题
Dec 06 Javascript
Jquery图形报表插件 jqplot简介及参数详解
Oct 10 Javascript
eclipse导入jquery包后报错的解决方法
Feb 17 Javascript
JavaScript实现向OL列表内动态添加LI元素的方法
Mar 21 Javascript
自定义jQuery插件方式实现强制对象重绘的方法
Mar 23 Javascript
Ionic快速安装教程
Jun 03 Javascript
使用js获取地址栏参数的方法推荐(超级简单)
Jun 14 Javascript
Vue.js教程之axios与网络传输的学习实践
Apr 29 Javascript
基于vue展开收起动画的示例代码
Jul 05 Javascript
浅析Vue中拆分视图层代码的5点建议
Aug 15 Javascript
Vue 利用指令实现禁止反复发送请求的两种方法
Sep 15 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实现上传图片生成缩略图示例
2014/04/13 PHP
新浪SAE搭建PHP项目教程
2015/01/28 PHP
jquery获取tr中控件值并操作tr实现思路
2013/03/27 Javascript
jquery自定义滚动条插件示例分享
2014/02/21 Javascript
基于jQuery实现复选框的全选 全不选 反选功能
2014/11/24 Javascript
nodejs中操作mysql数据库示例
2014/12/20 NodeJs
JavaScript实现同步于本地时间的动态时间显示方法
2015/02/02 Javascript
DOM 事件的深入浅出(二)
2016/12/05 Javascript
JavaWeb表单及时验证功能在输入后立即验证(含用户类型,性别,爱好...的验证)
2017/06/09 Javascript
NodeJS自定义模块写法(详解)
2017/06/27 NodeJs
javascript ES6 新增了let命令使用介绍
2017/07/07 Javascript
JavaScript惰性求值的一种实现方法示例
2019/01/11 Javascript
初学node.js中实现删除用户路由
2019/05/27 Javascript
Nodejs异步流程框架async的方法
2019/06/07 NodeJs
js回调函数仿360开机
2019/12/26 Javascript
JavaScript实现跟随鼠标移动的盒子
2021/01/28 Javascript
JavaScript如何实现防止重复的网络请求的示例
2021/01/28 Javascript
python爬虫使用cookie登录详解
2017/12/27 Python
Python用61行代码实现图片像素化的示例代码
2018/12/10 Python
python使用Plotly绘图工具绘制柱状图
2019/04/01 Python
Django ORM 聚合查询和分组查询实现详解
2019/08/09 Python
Python2与Python3的区别点整理
2019/12/12 Python
利用Python自动化操作AutoCAD的实现
2020/04/01 Python
基于Python3读写INI配置文件过程解析
2020/07/23 Python
用python实现学生管理系统
2020/07/24 Python
Python filter过滤器原理及实例应用
2020/08/18 Python
python 6行代码制作月历生成器
2020/09/18 Python
PyCharm+Miniconda3安装配置教程详解
2021/02/16 Python
世界上获奖最多的手机镜头:Olloclip
2018/03/03 全球购物
万豪国际住宅与别墅集团:Homes & Villas by Marriott International
2020/10/08 全球购物
政府法律服务方案
2014/06/14 职场文书
2016年党校科级干部培训班学习心得体会
2016/01/06 职场文书
CSS3常见动画的实现方式
2021/04/14 HTML / CSS
使用golang编写一个并发工作队列
2021/05/08 Golang
Ajax实现异步加载数据
2021/11/17 Javascript
美元符号 $
2022/02/17 杂记