Angular的*ngFor指令不更新视图
创始人
2024-10-24 01:00:33
0

使用不可变对象或手动触发变化检测

在Angular中,*ngFor指令通常用于遍历数组并生成相应的DOM元素。但是,当我们对数组进行修改时,视图并不总是会被更新。这是因为Angular默认采用的是引用比较的变化检测策略,而不是深度比较。因此,当我们修改数组时,其实是修改了同一个引用对象的内容,而不是创建了一个新的数组对象,导致变化检测无法触发。

为了解决这个问题,我们可以采用不可变对象的方式,即在修改数组时,创建一个全新的数组对象并赋值给原始数组,以此来触发视图的更新。例如:

this.items = [...this.items, newItem]; //添加新元素
this.items = this.items.filter(item => item != deletedItem); //删除元素

另一种方式是手动触发变化检测。我们可以注入ChangeDetectorRef服务,并调用其detectChanges()方法,以此来强制更新视图。例如:

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

constructor(private cdr: ChangeDetectorRef) {}

ngOnInit() {
  setInterval(() => {
    //修改数组
    this.cdr.detectChanges(); //手动触发变化检测
  }, 1000);
}

使用这两种方法之一,都可以确保视图正确地根据数组的变化来更新。

相关内容

热门资讯

玩家必看教程!wepoker私... 玩家必看教程!wepoker私人局俱乐部怎么进,佛手在线大菠萝智能辅助器,透视教程(有挂技巧)准备好...
透视教程!菠萝德州透视脚本(透... 透视教程!菠萝德州透视脚本(透视)确实真的有挂(详细辅助详细教程)1、机器人多个强度级别选择2、发牌...
一分钟秒懂!wepoker辅助... 1、一分钟秒懂!wepoker辅助器安装包,wepoker辅助器安装包,wpk教程(有挂攻略);详细...
透视线上!wepoker脚本(... 透视线上!wepoker脚本(透视)一贯是真的有挂(详细辅助攻略教程);wepoker脚本是一种具有...
关于!wepoker游戏下载,... 1、关于!wepoker游戏下载,aapoker破解侠是真的吗,可靠技巧(有挂软件)(UU poke...
透视软件!wepoker底牌透... 透视软件!wepoker底牌透视(透视)好像存在有挂(详细辅助细节揭秘)1、每一步都需要思考,不同水...
详细说明!wepoker是不是... 详细说明!wepoker是不是有人用挂,werplan外卦神器,攻略教程(有挂技巧);《WPK辅助透...
透视玄学!德州私人局怎么透视(... 透视玄学!德州私人局怎么透视(透视)果然真的是有挂(详细辅助必胜教程)1、ai机器人多个强度级别选择...
今日焦点!cloudpoker... 1、今日焦点!cloudpoker作弊,hhpoker为什么一直输,辅助教程(有挂攻略)。2、hhp...
透视数据!hhpoker怎么开... 透视数据!hhpoker怎么开透视(透视)其实存在有挂(详细辅助科技教程)1)hhpoker怎么开透...