Angular 6的*ngFor不更新视图
创始人
2024-10-16 07:00:45
0

在Angular 6中,*ngFor指令会根据数组的变化来更新视图。但是有时候,当数组的元素发生改变时,视图可能不会自动更新。以下是一些解决这个问题的方法:

  1. 使用不可变对象:确保在修改数组时,创建一个新的对象而不是直接修改原始数组。这可以通过使用数组的map()方法来实现。
this.array = this.array.map(item => Object.assign({}, item, { property: newValue }));
  1. 使用Angular提供的ChangeDetectorRef:ChangeDetectorRef允许手动触发Angular的变更检测机制,从而更新视图。

首先,在组件的构造函数中注入ChangeDetectorRef。

constructor(private cdr: ChangeDetectorRef) {}

然后,在修改数组后调用cdr.detectChanges()。

this.array = [...this.array];
this.cdr.detectChanges();
  1. 使用trackBy函数:在*ngFor指令中使用trackBy函数可以帮助Angular更好地识别数组元素的更新。

首先,在组件中定义一个trackBy函数。

trackByFn(index, item) {
  return item.id;
}

然后,在*ngFor指令中使用trackBy函数。

{{ item.property }}

这些方法可以帮助解决Angular 6中*ngFor不更新视图的问题。

相关内容

热门资讯

九分钟辅助!德州来玩辅助器,w... 九分钟辅助!德州来玩辅助器,wejoker辅助器要钱玩吗,攻略教程(有挂讲解)1、首先打开wejok...
五分钟辅助!xpoker辅助工... 五分钟辅助!xpoker辅助工具,wepoker有透视功能吗,绝活教程(证实有挂)1、该软件可以轻松...
第6分钟辅助!德扑HHpoke... 第6分钟辅助!德扑HHpoker有挂吗,hardrock透视工具,方案教程(了解有挂)1、下载好德扑...
第7分钟辅助!wepoker可... 第7分钟辅助!wepoker可以开透视吗,epoker免费透视脚本,指南教程(有挂教学)1、首先打开...
三分钟辅助!wepoker免费... 三分钟辅助!wepoker免费脚本咨询,aapoker如何设置胜率,手册教程(果真有挂)1、很好的工...
第7分钟辅助!wepoker私... 第7分钟辅助!wepoker私人局辅助,hhpoker是真的还是假的,法子教程(有挂透明挂)hhpo...
四分钟辅助!wepoker分析... 四分钟辅助!wepoker分析,werplan怎么透视,模板教程(有挂方式)该软件可以轻松地帮助玩家...
第6分钟辅助!哈糖大菠萝软件下... 第6分钟辅助!哈糖大菠萝软件下载,aapoker怎么开辅助器,法子教程(证实有挂)1、哈糖大菠萝软件...
七分钟辅助!hhpoker透视... 七分钟辅助!hhpoker透视方法,we poker辅助器下载,机巧教程(有挂存在)1、we pok...
三分钟辅助!werplan免费... 三分钟辅助!werplan免费挂下载,拱趴大菠萝挂怎么安装,项目教程(有挂方针)1、完成拱趴大菠萝挂...