子父组件传值

Angular 2 及以上版本中的父子组件通信方式

在 Angular 2 及以上版本中,父子组件通信主要通过以下几种方式实现:

一、使用@Input()进行父向子通信

父组件通过属性绑定的方式将数据传递给子组件,子组件使用@Input()装饰器来接收这些数据。

二、使用@Output()和事件发射器进行子向父通信

子组件通过发射自定义事件来通知父组件,父组件监听这些事件并作出响应。

下面通过一个详细的例子来说明这两种通信方式。

父组件(ParentComponent)

typescript 复制代码
import { Component } from '@angular/core';

@Component({
  selector: 'app-parent',
  template: `
    <h1>Parent Component</h1>
    <p>Message from Parent: {{ message }}</p>
    <input [(ngModel)]="message" placeholder="Type a message">
    <button (click)="sendMessageToChild()">Send Message to Child</button>
    <app-child [parentMessage]="message" (childEvent)="handleChildEvent($event)"></app-child>
  `
})
export class ParentComponent {
  message: string = 'Hello from Parent!';

  sendMessageToChild() {
    // 这里可以通过其他逻辑来决定发送什么消息
    this.message += ' (updated)';
    // 由于使用了双向绑定[(ngModel)],这里的 message 更新会自动反映到视图和子组件中
  }

  handleChildEvent(event: string) {
    console.log('Received event from child:', event);
    // 可以根据事件内容更新父组件的状态或执行其他操作
  }
}

子组件(ChildComponent)

typescript 复制代码
import { Component, Input, Output, EventEmitter } from '@angular/core';

@Component({
  selector: 'app-child',
  template: `
    <h2>Child Component</h2>
    <p>Message from Parent: {{ parentMessage }}</p>
    <button (click)="sendMessageToParent()">Send Message to Parent</button>
  `
})
export class ChildComponent {
  @Input() parentMessage: string; // 接收来自父组件的数据
  @Output() childEvent = new EventEmitter<string>(); // 发射自定义事件

  sendMessageToParent() {
    this.childEvent.emit('Hello from Child!'); // 发射事件并传递数据给父组件
  }
}

解释

  1. 父组件模板
    • 使用[(ngModel)]实现双向数据绑定,这样输入框中的值会实时更新到message变量中。
    • 使用[parentMessage]="message"将父组件的message变量传递给子组件的parentMessage输入属性。
    • 使用(childEvent)="handleChildEvent($event)"监听子组件发射的childEvent事件,并在事件发生时调用handleChildEvent方法。
  2. 子组件装饰器
    • 使用@Input()装饰器来声明一个输入属性parentMessage,用于接收父组件传递过来的数据。
    • 使用@Output()装饰器和一个EventEmitter实例来声明一个输出属性childEvent,用于发射自定义事件。
  3. 子组件方法
    • sendMessageToParent方法通过调用this.childEvent.emit(...)来发射事件,并传递数据给父组件。

通过这种方式,父组件可以轻松地将数据传递给子组件,而子组件也可以通过发射事件来与父组件进行通信。这种机制是 Angular 中实现组件间通信的一种常用且强大的方式。

相关推荐
IT布道1 天前
解决angular与jetty websocket 每30s自动断连的问题
websocket·angular.js·jetty
葡萄城技术团队7 天前
在 Angular 应用程序中使用 Genkit 的完整指南
前端·angular.js
界面开发小八哥9 天前
界面控件Kendo UI for Angular 2025 Q2新版亮点 - 增强跨设备的无缝体验
前端·ui·界面控件·kendo ui·angular.js
蓝乐9 天前
Angular项目IOS16.1.1设备页面空白问题
前端·javascript·angular.js
欧阳天羲12 天前
Angular 框架下 AI 驱动的企业级大前端应用开
前端·人工智能·angular.js
甜瓜看代码17 天前
1.
react.js·node.js·angular.js
天若有情67318 天前
React、Vue、Angular的性能优化与源码解析概述
vue.js·react.js·angular.js
啃火龙果的兔子20 天前
Angular 从框架搭建到开发上线的完整流程
前端·javascript·angular.js
葡萄城技术团队21 天前
Angular V20 新特性
angular.js
hashiqimiya1 个月前
AngularJS 待办事项 App
前端·javascript·angular.js