在Angular 6中,可以使用@Output装饰器在父子组件之间进行通信。
首先,在父组件中定义一个输出属性,并使用@Output装饰器标记它。然后在子组件中,使用EventEmitter类创建一个事件,并将其分配给输出属性。最后,当子组件中的事件触发时,它将通过输出属性向父组件发送数据。
以下是一个使用@Output进行父子组件通信的示例:
父组件:
import { Component } from '@angular/core';
@Component({
selector: 'app-parent',
template: `
Parent Component
{{message}}
`,
})
export class ParentComponent {
message: string;
receiveMessage($event) {
this.message = $event;
}
}
子组件:
import { Component, Output, EventEmitter } from '@angular/core';
@Component({
selector: 'app-child',
template: `
Child Component
`,
})
export class ChildComponent {
@Output() messageEvent = new EventEmitter();
sendMessage() {
this.messageEvent.emit('Hello from Child');
}
}
在父组件中,我们定义了一个message属性来接收子组件发送的消息。我们还定义了一个receiveMessage方法,当子组件发送消息时,它将被调用。
在子组件中,我们使用@Output装饰器定义了一个messageEvent输出属性,并创建了一个sendMessage方法来触发该属性并发送消息。
最后,我们在父组件的模板中使用app-child组件,并使用(messageEvent)="receiveMessage($event)"语法来监听子组件发送的消息,并调用receiveMessage方法来接收消息。
当点击子组件中的按钮时,它会触发sendMessage方法,并通过messageEvent属性向父组件发送消息。
这样,父子组件之间就可以通过@Output进行通信了。