Angular@Input()在父组件中更改值时不更新,即使使用了ngOnChanges。
创始人
2024-10-23 03:30:24
0

通过使用 ngOnChanges 钩子和 SimpleChanges 对象,可以在 @Input() 值更改时触发更新。为了确保更新发生,可以通过在父组件中创建一个 setter 方法来更新 @Input() 属性。

下面是一个演示如何更新 @Input() 属性的示例代码:

子组件:

import { Component, Input, OnChanges, SimpleChanges } from '@angular/core';

@Component({
  selector: 'app-child',
  template: `
{{message}}
` }) export class ChildComponent implements OnChanges { @Input() message: string; ngOnChanges(changes: SimpleChanges) { for (let propName in changes) { let change = changes[propName]; if (propName === 'message') { this.message = change.currentValue; } } } }

父组件:

import { Component } from '@angular/core';

@Component({
  selector: 'app-parent',
  template: `
    
    
  `
})
export class ParentComponent {
  myMessage = "Hello World!";

  updateMessage() {
    this.myMessage = "Updated Message";
  }
}

在这个示例中,当点击按钮时,父组件中的 myMessage 属性将被更新,从而更新子组件中的 message 属性。ngOnChanges 钩子在属性更改时会触发更新,从而确保子组件中的 message 属性与父组件中的 myMessage 属性一致。

注意,这个示例只是一个简单的演示,实际应用中可能需要更复杂的逻辑。

相关内容

热门资讯

透视脚本!wepoker辅助器... 透视脚本!wepoker辅助器(透视)wepoker轻量版透视(都是一直总是有辅助器)-哔哩哔哩1、...
透视app!丽水都莱辅助软件(... 透视app!丽水都莱辅助软件(辅助)潮友辅助器开挂软件(一贯一直总是有挂)-哔哩哔哩1、在潮友辅助器...
透视技巧!德州局怎么透视(透视... 透视技巧!德州局怎么透视(透视)hhpoker免费透视脚本(其实是有脚本)-哔哩哔哩一、hhpoke...
透视技巧!wepoker辅助器... 透视技巧!wepoker辅助器软件下载(透视)wepoker高级辅助(切实是真的有挂)-哔哩哔哩1....
透视神器!wepoker透视脚... 您好,wepoker透视脚本苹果版这款游戏可以开挂的,确实是有挂的,需要了解加去威信【4852750...
透视工具!hhpoker作必弊... 透视工具!hhpoker作必弊码(透视)hhpoker怎么破解(本来是有挂)-哔哩哔哩一、hhpok...
透视技巧!wepoker数据分... 透视技巧!wepoker数据分析(透视)wepoker可以透视码(一直一直都是有透视)-哔哩哔哩1、...
透视方法!wepoker私人局... 透视方法!wepoker私人局俱乐部(透视)wepoker私人局有透视吗(本来一直都是有辅助器)-哔...
透视技巧!wepoker祈福有... 透视技巧!wepoker祈福有用吗(透视)wejoker免费脚本(果然一直都是有脚本)-哔哩哔哩1、...
透视app!wpk辅助购买(透... 透视app!wpk辅助购买(透视)wpk俱乐部是真的吗(都是存在有透视)-哔哩哔哩1、每一步都需要思...