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;
  }
}

相关内容

热门资讯

透视app!wepoker买钻... 透视app!wepoker买钻石有用吗(透视)wepoker辅助器安装包(都是存在有透视)-哔哩哔哩...
透视神器!wepoker手机版... 透视神器!wepoker手机版透视脚本(透视)wepoker辅助工具(竟然一直都是有透视)-哔哩哔哩...
透视教程!wepoker免费脚... 透视教程!wepoker免费脚本(透视)wepoker免费辅助器(总是有挂)-哔哩哔哩1、玩家可以在...
透视app!wepokerpl... 透视app!wepokerplus作必弊(透视)wepoker透视是真的吗(真是有脚本)-哔哩哔哩一...
透视工具!德扑之心免费透视(透... 透视工具!德扑之心免费透视(透视)德普之星怎么开辅助(果然一直都是有脚本)-哔哩哔哩1、德普之星怎么...
透视app!wepoker线上... 透视app!wepoker线上大神(透视)黑侠破解wepoker(都是是有辅助器)-哔哩哔哩1.黑侠...
透视方法!hhpoker作必弊... 透视方法!hhpoker作必弊码怎么用(透视)hhpoker透视脚本下载(一贯真的有挂)-哔哩哔哩1...
透视app!德普之星的辅助工具... 透视app!德普之星的辅助工具介绍(透视)德普之星辅助工具如何设置(其实是有透视)-哔哩哔哩1、在德...
透视教程!越乡游义乌辅助器(辅... 透视教程!越乡游义乌辅助器(辅助)圣游辅助软件(原来是真的有辅助器)-哔哩哔哩1、起透看视 越乡游义...
透视攻略!hhpoker是正品... 透视攻略!hhpoker是正品吗(透视)hhpoker真的有透视吗(确实真的有挂)-哔哩哔哩1、hh...