Angular2 组件间通过@Input @Output通讯示例
本文介绍了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); } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
angularjs利用directive实现移动端自定义软键盘的示例
下面小编就为大家带来一篇angularJS利用directive实现移动端自定义软键盘的示例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧2017-09-09解决ng-repeat产生的ng-model中取不到值的问题
今天小编就为大家分享一篇解决ng-repeat产生的ng-model中取不到值的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2018-10-10详解angularjs获取元素以及angular.element()用法
本篇文章主要介绍了详解angularjs获取元素以及angular.element()用法 ,具有一定的参考价值,有兴趣的可以了解一下2017-07-07AngularJS基于ngInfiniteScroll实现下拉滚动加载的方法
这篇文章主要介绍了AngularJS基于ngInfiniteScroll实现下拉滚动加载的方法,结合实例形式分析AngularJS下拉滚动插件ngInfiniteScroll的下载、功能、属性及相关使用方法,需要的朋友可以参考下2016-12-12详解在Angular4中使用ng2-baidu-map的方法
这篇文章主要介绍了在Angular4中使用ng2-baidu-map的方法,本文分步骤给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下2019-06-06
最新评论