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 相关文章推荐
Ext第一周 史上最强学习笔记---GridPanel(基础篇)
Dec 29 Javascript
JS中setTimeout()的用法详解
Apr 14 Javascript
js获取客户端外网ip的简单实例
Nov 21 Javascript
js获取url中指定参数值的示例代码
Dec 14 Javascript
JS实现点击链接取消跳转效果的方法
Jan 24 Javascript
JS制作简单的三级联动
Mar 18 Javascript
最精简的JavaScript实现鼠标拖动效果的方法
May 11 Javascript
学习javascript面向对象 掌握创建对象的9种方式
Jan 04 Javascript
JS中JSON对象和String之间的互转及处理技巧
Apr 06 Javascript
vue + element-ui实现简洁的导入导出功能
Dec 22 Javascript
vue的滚动条插件实现代码
Sep 07 Javascript
vue使用swiper.js重叠轮播组建样式
Nov 14 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 计算两个时间戳相隔的时间的函数(小时)
2009/12/18 PHP
JavaScript中void(0)的具体含义解释
2007/02/27 Javascript
js类后台管理菜单类-MenuSwitch
2007/09/12 Javascript
获取body标签的两种方法
2011/10/13 Javascript
jquery触发a标签跳转事件示例代码
2013/07/21 Javascript
showModalDialog在谷歌浏览器下会返回Null的解决方法
2013/11/27 Javascript
ie下$.getJSON出现问题的解决方法
2014/02/12 Javascript
jQuery实现仿腾讯迷你首页选项卡效果代码
2015/09/17 Javascript
JavaScript使用DeviceOne开发实战(三)仿微信应用
2015/12/02 Javascript
jQuery实现的tab标签切换效果示例
2016/09/05 Javascript
jQuery 选择符详细介绍及整理
2016/12/02 Javascript
js 索引下标之li集合绑定点击事件
2018/01/12 Javascript
使用typescript开发angular模块并发布npm包
2018/04/19 Javascript
node 命令方式启动修改端口的方法
2018/05/12 Javascript
jQuery表单元素过滤选择器用法实例分析
2019/02/20 jQuery
浅谈vue限制文本框输入数字的正确姿势
2019/09/02 Javascript
Vue2.0 ES6语法降级ES5的操作
2020/10/30 Javascript
js实现随机点名功能
2020/12/23 Javascript
Python 网页解析HTMLParse的实例详解
2017/08/10 Python
详解Numpy数组转置的三种方法T、transpose、swapaxes
2019/05/27 Python
解决Python3 抓取微信账单信息问题
2019/07/19 Python
python3.6、opencv安装环境搭建过程(图文教程)
2019/11/05 Python
django序列化serializers过程解析
2019/12/14 Python
jupyter 使用Pillow包显示图像时inline显示方式
2020/04/24 Python
PHP基于phpqrcode类库生成二维码过程解析
2020/05/28 Python
Python操作MySQL数据库的示例代码
2020/07/13 Python
最好的意大利皮夹克:D’Arienzo
2018/12/04 全球购物
澳大利亚体育和露营装备在线/实体零售商:Find Sports
2020/06/03 全球购物
专升本自我鉴定
2013/10/10 职场文书
英语文学专业学生的自我评价
2013/10/31 职场文书
党校培训思想汇报
2014/01/03 职场文书
农村门前三包责任书
2014/07/25 职场文书
检讨书格式
2015/05/07 职场文书
MySQL 数据类型详情
2021/11/11 MySQL
为什么MySQL不建议使用SELECT *
2022/04/03 MySQL