Angular2 组件间通过@Input @Output通讯示例


Posted in Javascript onAugust 24, 2017

本文介绍了Angular2 组件间通过@Input @Output通讯示例,分享给大家,具体如下:

父组件传给子组件:

子组件设置@Input属性,父组件即可通过设置html属性给子组件传值。

子组件:

@Input() title:string;
 _name:string = '';

 @Input() set name(name:string) {
  this._name=(name&&name.trim())||'';
 }

上面的代码设置了两个可供父组件传入的属性:title和name,当设置name属性时,set name(name:string)方法会执行,如果不需要处理setter,那么用title的形式,一行代码声明即可.

父组件调用:

<app-header [title]="title" name="姓名"></app-header>

调用方法有两种,属性名用中括号包围的title,值title是父组件中的对象名,而name没有用中括号,后面的值就是传给子组件的字符串。当然,不用中括号,也可以用{{name}}传对象的值。

如果要监听传入属性值的变化,可以在子组件实现OnChanges(@angular/core中)接口:

export class HeaderComponent implements OnChanges {
 ngOnChanges(changes: SimpleChanges): void {
  console.log(changes['title']);
 }
 @Input() title:string;
 _name:string = '';

 @Input() set name(name:string) {
  this._name=(name&&name.trim())||'';
 }

}

SimpleChanges 是一个用属性名作key的数组,通过属性名取出对象,对象里包含该属性变化前(previousValue)后(currentValue)的值。

父组件监听子组件变化

子组件通过@Output()暴露EventEmitter,父组件在声明子组件时增加EventEmitter的回调方法,子组件在需要的时候弹射事件,父组件的回调方法里就能收到。

子组件:

export class HeaderComponent implements OnChanges {
 ngOnChanges(changes: SimpleChanges): void {
  console.log(changes['title']);
 }
 @Input() title:string;
 _name:string = '';

 @Input() set name(name:string) {
  this._name=(name&&name.trim())||'';
 }
 //声明事件发射器
 @Output() checkEmitter=new EventEmitter<boolean>();
 //用于绑定checkbox的checked属性
 isChecked=true;

 toggle() {
  this.isChecked=!this.isChecked;
  //发射事件
  this.checkEmitter.emit(this.isChecked);
 }
}

子组件模板:

<p>
 {{title}}
</p>
<p><input type="checkbox" name="cb" [(ngModel)]="isChecked" (click)="toggle()" />Checkbox <br /></p>

父组件中声明:

<app-header [title]="title" name="{{name}}" (checkEmitter)="onCheckedChange($event)" ></app-header>

父组件事件回调接收:

export class AppComponent implements AfterViewInit{
 ngAfterViewInit() {

 }
 onCheckedChange(isChecked:boolean) {
  console.log("checkbox选中状态:"+isChecked);
 }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
一个关于jqGrid使用的小例子(行按钮)
Nov 04 Javascript
JQuery插入DOM节点的方法
Jun 11 Javascript
轻量级jQuery插件slideBox实现带底栏轮播(焦点图)代码
Mar 28 Javascript
javascript截图 jQuery插件imgAreaSelect使用详解
May 04 Javascript
javascript css红色经典选项卡效果实现代码
May 17 Javascript
JS自定义混合Mixin函数示例
Nov 26 Javascript
vue.js中v-on:textInput无法执行事件问题的解决过程
Jul 12 Javascript
Webpack性能优化 DLL 用法详解
Aug 10 Javascript
在vue-cli搭建的项目中增加后台mock接口的方法
Apr 26 Javascript
基于jQuery ztree实现表格风格的树状结构
Aug 31 jQuery
在vue中对数组值变化的监听与重新响应渲染操作
Jul 17 Javascript
一百多行代码实现react拖拽hooks
Mar 23 Javascript
Angular2 组件交互实例详解
Aug 24 #Javascript
使用jQuery实现页面定时弹出广告效果
Aug 24 #jQuery
探究react-native 源码的图片缓存问题
Aug 24 #Javascript
详解vue.js之绑定class和style的示例代码
Aug 24 #Javascript
10个最优秀的Node.js MVC框架
Aug 24 #Javascript
Vue.js实现输入框绑定的实例代码
Aug 24 #Javascript
Vue.js实现价格计算器功能
Mar 30 #Javascript
You might like
PHP无限分类(树形类)的深入分析
2013/06/02 PHP
php 获取本地IP代码
2013/06/23 PHP
解析php做推送服务端实现ios消息推送
2013/07/01 PHP
Yii2实现自定义独立验证器的方法
2017/05/05 PHP
DOM 基本方法
2009/07/18 Javascript
jquery animate图片模向滑动示例代码
2011/01/26 Javascript
json数据处理技巧(字段带空格、增加字段、排序等等)
2013/06/14 Javascript
Javascript遍历Html Table示例(包括内容和属性值)
2014/07/08 Javascript
如何在MVC应用程序中使用Jquery
2014/11/17 Javascript
clipboard.js无需Flash无需依赖任何JS库实现文本复制与剪切
2015/10/10 Javascript
使用JQuery实现Ctrl+Enter提交表单的方法
2015/10/22 Javascript
js纯数字逐一停止显示效果的实现代码
2016/03/16 Javascript
jQuery中show与hide方法用法示例
2016/09/16 Javascript
jquery实现左右滑动式轮播图
2017/03/02 Javascript
详解vue-cil和webpack中本地静态图片的路径问题解决方案
2017/09/27 Javascript
Angular 作用域scope的具体使用
2017/12/11 Javascript
浅析vue-router jquery和params传参(接收参数)$router $route的区别
2018/08/03 jQuery
vue.js实现备忘录demo
2019/06/26 Javascript
element表格翻页第2页从1开始编号(后端从0开始分页)
2019/12/10 Javascript
vue 调用 RESTful风格接口操作
2020/08/11 Javascript
小程序中手机号识别的示例
2020/12/14 Javascript
python操作mysql代码总结
2018/06/01 Python
python处理multipart/form-data的请求方法
2018/12/26 Python
使用Django简单编写一个XSS平台的方法步骤
2019/03/25 Python
Python多线程threading模块用法实例分析
2019/05/22 Python
使用python socket分发大文件的实现方法
2019/07/08 Python
pandas如何处理缺失值
2019/07/31 Python
详解python3中用HTMLTestRunner.py报ImportError: No module named 'StringIO'如何解决
2019/08/27 Python
python 下划线的不同用法
2020/10/24 Python
澳大利亚香水在线:Price Rite Mart
2017/12/28 全球购物
三严三实对照检查材料思想汇报
2014/09/28 职场文书
敬业奉献模范事迹材料
2014/12/24 职场文书
初中政治教学工作总结
2015/08/13 职场文书
高中数学课堂教学反思
2016/02/18 职场文书
详解redis分布式锁的这些坑
2021/05/19 Redis
Python如何识别银行卡卡号?
2021/06/10 Python