Angular在对象数组中添加新对象后不会更新
创始人
2024-10-30 19:30:53
0

这可能是由于Angular对数组中的对象进行了浅层比较而导致的。为了解决这个问题,您可以使用切换数组引用的方法来更新视图。可以通过以下两种方式之一实现:

方法一:

在您的组件中,创建一个新的数组,然后使用 Array.push() 方法将新对象推入该数组。然后将该数组分配给原始数组的引用。这将强制Angular重新渲染组件,并更新视图,使新对象显示出来。

示例代码如下:

originalArray: Object[] = [{id: 1, name: 'John'}, {id: 2, name: 'Doe'}]; newObject: Object = {id: 3, name: 'Alice'};

addToOriginalArray() { let tempArray = this.originalArray.slice(); // create a copy of original array tempArray.push(this.newObject); // push new object to temp array this.originalArray = tempArray; // assign temp array to original array reference }

方法二:

使用 Angular 的 change detection 将变更检测策略更改为 OnPush。这将防止Angular每次更改检查时都进行全面调用,并使它仅在输入对象更改时才调用。在这种情况下,您需要通过具有新值的对象将输入对象重写。

示例代码如下:

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

@Component({ selector: 'app-my-component', templateUrl: './my-component.component.html', styleUrls: ['./my-component.component.css'], changeDetection: ChangeDetectionStrategy.OnPush // change change detection strategy }) export class MyComponent { @Input() originalArray: Object[] = [{id: 1, name: 'John'}, {id: 2, name: 'Doe'}]; @Input() newObject: Object = {id: 3, name: 'Alice'};

addToOriginalArray() { let tempArray = this.originalArray.slice(); // create a copy of original array

相关内容

热门资讯

wepoke辅助挂!wepok... wepoke辅助挂!wepok软件透明挂(透视辅助)wepOkE(果真真的有挂);wepOkE软件透...
aapoker透明挂!wpk微... aapoker透明挂!wpk微扑克系统发牌规律,微扑克软件开发(详细透视教程);(需添加指定薇757...
微扑克游戏辅助器!微扑克辅助钻... 1、微扑克游戏辅助器!微扑克辅助钻石,微扑克有挂,解说技巧(有挂辅助挂)2、进入游戏-大厅左侧-新手...
微扑克ai辅助!Wpk果真真的... 微扑克ai辅助!Wpk果真真的有挂,wPK一般真的有挂,2025新版总结(有挂教程)1、进入游戏-大...
wpk透明挂!德州线上扑克辅助... wpk透明挂!德州线上扑克辅助,德扑之星比赛创建设置(详细透视挂教程)是一款可以让一直输的玩家,快速...
透牌教程!wepoke辅助挂(... 大家肯定在之前wepoKE或者wepoKE中玩过透牌教程!wepoke辅助挂(wepoke辅助技巧)...
微扑克辅助机器人!微扑克ai辅... 您好,微扑克这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家在这款游戏中...
wpk提高胜率!wpk透视,W... wpk提高胜率!wpk透视,Wpk其实真的有挂,详细教程,(有挂脚本)运wpk辅助工具,进入游戏界面...
wepoke智能ai!德扑之星... wepoke智能ai!德扑之星可以操作,aapoker有手游版(详细辅助教程)1、每一步都需要思考,...
2025新版技巧!wepoke... 2025新版技巧!wepoke小技巧(wepoke辅助德之星)WePoKer(原来真的有挂) 科技详...