Angular深拷贝的子组件输入无法在UI上更改
创始人
2024-10-29 11:30:06
0

在深拷贝时,会创建一个新的对象,因此在 UI 上更改该对象的属性时,并不会影响原始对象。为了解决这个问题,请在子组件中使用 EventEmitter 来将更改传递回父组件,并在父组件中更新原始对象。

示例代码:

子组件:

import { Component, EventEmitter, Input, Output } from '@angular/core';

@Component({
  selector: 'child-component',
  template: `
    
  `,
})
export class ChildComponent {
  private innerValue: any = {};

  @Input() set value(value: any) {
    this.innerValue = { ...value };
  }

  @Output() valueChange = new EventEmitter();

  onModelChange() {
    this.valueChange.emit(this.innerValue);
  }
}

父组件:

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

@Component({
  selector: 'parent-component',
  template: `
    
  `,
})
export class ParentComponent {
  originalValue = { prop1: '', prop2: '' };
  
  onValueChange(newValue) {
    // 更新原始对象
    this.originalValue = newValue;
  }
}

相关内容

热门资讯

关于透视!fishpoker透... 关于透视!fishpoker透视底牌!总是真的是有辅助方法(有挂实锤)-哔哩哔哩1、fishpoke...
关于透视!xpoker透视辅助... 关于透视!xpoker透视辅助!都是真的有辅助工具(有挂功能)-哔哩哔哩1、完成xpoker透视辅助...
解谜透视!哈糖大菠萝怎么挂!切... 解谜透视!哈糖大菠萝怎么挂!切实存在有辅助神器(有挂神器)-哔哩哔哩1、进入游戏-大厅左侧-新手福利...
揭露透视!聚星ai辅助工具下载... 揭露透视!聚星ai辅助工具下载!原来真的有辅助教程(详细教程)-哔哩哔哩1、在聚星ai辅助工具下载插...
解迷透视!cloudpoker... 解迷透视!cloudpoker外开挂!其实存在有辅助神器(果真有挂)-哔哩哔哩1、这是跨平台的clo...
揭幕透视!werplan外卦神... 揭幕透视!werplan外卦神器!其实是真的有辅助app(有人有挂)-哔哩哔哩1、werplan外卦...
有挂透视!佛手在线大菠萝智能辅... 有挂透视!佛手在线大菠萝智能辅助器!好像是有辅助工具(有挂方法)-哔哩哔哩1)佛手在线大菠萝智能辅助...
开挂透视!约局吧德州真的有透视... 开挂透视!约局吧德州真的有透视挂吗!本来有辅助攻略(有挂存在)-哔哩哔哩亲,关键说明,约局吧德州真的...
总结透视!pokermaste... 总结透视!pokermaster辅助器!好像是真的有辅助神器(竟然有挂)-哔哩哔哩1、pokerma...
详情透视!红龙poker辅助工... 详情透视!红龙poker辅助工具!一直一直总是有辅助工具(讲解有挂)-哔哩哔哩1、让任何用户在无需红...