angular在默认变更检测期间如何处理对象或对象数组的比较?
创始人
2024-10-30 20:30:34
0

在Angular中,当进行默认的变更检测时,如果需要比较两个对象或对象数组是否相同,会默认使用JavaScript中的“引用比较”,即比较它们的引用地址是否一致。这意味着如果两个对象或对象数组的引用地址不同,即使它们的属性值相同,它们也会被视为不同的。

如果想要进行“深度比较”,即比较两个对象或对象数组的属性值是否相同,可以使用Angular中的ChangeDetectorRef的detectChanges方法来触发变更检测,并传递一个选项对象,其中包含了一个名为“cmp”的函数。这个“cmp”函数会被用来进行深度比较。示例如下:

import { Component, ChangeDetectorRef, IterableDiffers } from '@angular/core';

@Component({
  selector: 'app-root',
  template: `
    
  • {{ item.name }}
` }) export class AppComponent { items = [{ name: 'item 1' }, { name: 'item 2' }, { name: 'item 3' }]; iterableDiffer: any; constructor(private cdr: ChangeDetectorRef, private iterableDiffers: IterableDiffers) { this.iterableDiffer = this.iterableDiffers.find([]).create(null); } cmp(index: number, o1: any, o2: any) { return o1.name === o2.name; } addItem() { this.items.push({ name: `item ${this.items.length + 1}` }); this.cdr.detectChanges({ // 传递cmp函数以进行深度比较 cmp: this.cmp.bind(this) }); } );

在这个示例中,我们首先注入了ChangeDetectorRef和IterableDiffers,然

相关内容

热门资讯

透视绝活!werplan怎么透... 透视绝活!werplan怎么透视,wepoker破解游戏盒子(透视)竟然真的有挂(哔哩哔哩)1)we...
透视窍门!wepoker俱乐部... 透视窍门!wepoker俱乐部辅助,红龙poker辅助平台(透视)好像真的有挂(哔哩哔哩)1、透视窍...
透视窍门!wepoker破解版... 透视窍门!wepoker破解版内购,werplan怎么透视(透视)总是是有挂(哔哩哔哩)1、每一步都...
透视讲义!hhpoker德州机... 透视讲义!hhpoker德州机器人,聚星ai辅助工具激活码(透视)一贯是真的挂(哔哩哔哩)1、游戏颠...
透视绝活!hhpkoer辅助器... 透视绝活!hhpkoer辅助器视频,newpoker脚本(透视)原来存在有挂(哔哩哔哩)1、不需要A...
透视模板!wepoker开脚本... 透视模板!wepoker开脚本视频,aapoker辅助软件合法吗(透视)都是真的有挂(哔哩哔哩)一、...
透视窍门!德普之星私人局辅助免... 您好,德普之星私人局辅助免费这款游戏可以开挂的,确实是有挂的,需要了解加去威信【136704302】...
透视秘籍!wepokerplu... 透视秘籍!wepokerplus作必弊,sohoo poker辅助(透视)竟然真的是有挂(哔哩哔哩)...
透视经验!wepoker免费脚... 透视经验!wepoker免费脚本弱密码,aapoker安装包怎么使用(透视)一贯有挂(哔哩哔哩)1)...
透视资料!佛手大菠萝13道挂哪... 透视资料!佛手大菠萝13道挂哪里,hhpoker透视方法(透视)真是存在有挂(哔哩哔哩)1、下载好佛...