速看:一文详解Angular父子组件间传数据的方法

时间:2023-01-04 20:58:47       来源:转载
本篇文章带大家了解一下Angular父子组件(Component)之间传递数据的方法,介绍一下Angular中父组件向子组件传数据、子组件向父组件传数据的方法,希望对大家有所帮助!

环境:Angular CLI: 11.0.6Angular: 11.0.7Node: 12.18.3npm : 6.14.6IDE: Visual Studio Code
登录后复制

组件之间传递数据,最主要的就是父子组件之间传递数据, 例如:

  
登录后复制

父组件传入数据给子组件,同时,子组件数据发生变化是,希望能够通知父组件。


(相关资料图)

Angular 中,@Input() 和 @Output() 为子组件提供了一种与其父组件通信的方法。 @Input() 允许父组件更新子组件中的数据。相反,@Output() 允许子组件向父组件发送数据。

父传子 @Input()

1. 子组件定义@Input()

子组件中的 @Input() 装饰器表示该属性可以从其父组件中获取值。【相关教程推荐:angular教程、编程教学】

例如:

export class ChildComponent {  @Input() message: string;}
登录后复制

增加@Input() 装饰器的变量,除了数据可以从父组件传入后,其他逻辑和普通变量一致;

子组件的html代码中,既可使用message这个变量, 例如:

Parent says: {{message}}

登录后复制

2. 父组件传递变量给子组件

当父组件调用子组件时,可以把父组件的变量(如messageToChild) 传递给子组件

登录后复制

子传父 @Output()

Angular通过事件(Event)来实现子组件通知父组件数据的改变,父组件需要订阅该事件。

1. 子组件定义@Output

子组件定义@Output

export class ChildComponent {  // EventEmitter ,这意味着它是一个事件  // new EventEmitter() -   // 使用 Angular 来创建一个新的事件发射器,它发出的数据是 string 类型的。  @Output() newItemEvent = new EventEmitter();  addNewItem(value: string) {    this.newItemEvent.emit(value);  }}
登录后复制

子组件当数据发生变化时,调用这个addNewItem方法既可。例如,html中

登录后复制

2. 父组件订阅事件

1、父组件的ts代码中,增加一个处理上面事件的方法,例如

addItem(newItem: string) {    // logic here}
登录后复制

2、父组件的html中,订阅该事件。

登录后复制

事件绑定 (newItemEvent)="addItem($event)"会把子组件中的 newItemEvent 事件连接到父组件的 addItem() 方法。

总结

使用@Input() 和 @Output() 可以很方便的实现父子组件之间的数据传递、共享。

可以同时使用 @Input() 和 @Output()

更多编程相关知识,请访问:编程视频!!

以上就是一文详解Angular父子组件间传数据的方法的详细内容,更多请关注php中文网其它相关文章!

关键词: 发生变化 相关文章