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中使用&quot;with&quot;语句中跨frame的变量引用问题
Mar 08 Javascript
js 获取子节点函数 (兼容FF与IE)
Apr 18 Javascript
javascript 基础篇2 数据类型,语句,函数
Mar 14 Javascript
JS实现静止元素自动移动示例
Apr 14 Javascript
JS实现同一个网页布局滑动门和TAB选项卡实例
Sep 23 Javascript
jQuery ajaxSubmit 实现ajax提交表单局部刷新
Jul 04 Javascript
Angular.js实现注册系统的实例详解
Dec 18 Javascript
原生JS实现圆环拖拽效果
Apr 07 Javascript
js实现ATM机存取款功能
Oct 27 Javascript
JavaScript函数IIFE使用详解
Oct 21 Javascript
vue3.0实现插件封装
Dec 14 Vue.js
利用node.js开发cli的完整步骤
Dec 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/08/18 PHP
ThinkPHP实现批量删除数据的代码实例
2014/07/02 PHP
PHP+shell实现多线程的方法
2015/07/01 PHP
php上传图片类及用法示例
2016/05/11 PHP
php图片添加水印例子
2016/07/20 PHP
PHP实现递归目录的5种方法
2016/10/27 PHP
tp5.1 框架数据库-数据集操作实例分析
2020/05/26 PHP
table行随鼠标移动变色示例
2014/05/07 Javascript
jQuery简单实现日历的方法
2015/05/04 Javascript
JQueryEasyUI之DataGrid数据显示
2016/11/23 Javascript
微信小程序 picker 组件详解及简单实例
2017/01/10 Javascript
mongoose中利用populate处理嵌套的方法
2017/05/26 Javascript
Vue.js简易安装和快速入门(第二课)
2017/10/17 Javascript
快速解决brew安装特定版本flow的问题
2018/05/17 Javascript
Vue常见面试题整理【值得收藏】
2018/09/20 Javascript
JS中类的静态方法,静态变量,实例方法,实例变量区别与用法实例分析
2020/03/14 Javascript
Python中使用socket发送HTTP请求数据接收不完整问题解决方法
2015/02/04 Python
python去掉行尾的换行符方法
2017/01/04 Python
Python编程实现双击更新所有已安装python模块的方法
2017/06/05 Python
Python优先队列实现方法示例
2017/09/21 Python
python文件选择对话框的操作方法
2019/06/27 Python
pybind11在Windows下的使用教程
2019/07/04 Python
Python对wav文件的重采样实例
2020/02/25 Python
Python 统计位数为偶数的数字代码详解
2020/03/15 Python
想学画画?python满足你!
2020/12/24 Python
HTML5 LocalStorage 本地存储刷新值还在
2017/03/10 HTML / CSS
美国知名户外用品畅销中心:Sierra Trading Post
2016/07/19 全球购物
九州传奇上机题
2014/07/10 面试题
设备售后服务承诺书
2014/05/30 职场文书
乡镇干部个人对照检查材料(群众路线)
2014/09/26 职场文书
三峡人家导游词
2015/01/31 职场文书
2015年乡镇卫生院妇幼保健工作总结
2015/05/19 职场文书
结婚纪念日感言
2015/08/01 职场文书
iPhone13 Pro外观确定,升级4800万镜头,4月20日发新品
2021/04/15 数码科技
weblogic服务建立数据源连接测试更新mysql驱动包的问题及解决方法
2022/01/22 MySQL
python函数的两种嵌套方法使用
2022/04/02 Python