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

网友投稿 213 2023-04-15


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的形式,一行代码声明即可.

父组件调用:

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

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

export clGOlLrzsMVass 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 implhttp://ements 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();

//用于绑定checkbox的checked属性

isChecked=true;

toggle() {

this.isChecked=!this.isChecked;

//发射事件

this.checkEmitter.emit(this.isChecked);

}

}

子组件模板:

{{title}}

Checkbox

父组件中声明:

复制代码 代码如下:

父组件事件回调接收:

export class AppComponent implements AfterViewInit{

ngAfterViewInit() {

}

onCheckedChange(isChecked:boolean) {

console.log("checkbox选中状态:"+isChecked);

}

}


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:浏览器插件mock工具(实用的浏览器插件)
下一篇:详解Angular4 路由设置相关
相关文章

 发表评论

暂时没有评论,来抢沙发吧~