angular - 即使实际值相同,组件也会在状态更改时重新渲染
问题描述
我的ngrx状态包含一系列项目:
export interface MyState {
myItems: ItemType[];
}
我有一个包含带有异步管道的ngFor的组件。
标记:
<app-my-item-details-card *ngFor="let myItem of myItems$ | async"> </app-my-item-details-card>
选择器:
this.myItems$ = createSelector(getMyState, state => state.myItems);
在 AppMyItemDetailsCardComponent 内部,我有一个布尔标志displayDetails:boolean和按钮按钮 (click)="displayDetails = !displayDetails" 来切换布尔标志。在详细信息面板上,我有一些输入显示来自传递给组件的MyItem实例的一些数据。用户可以修改这些 html 元素并单击Save按钮,该按钮会触发MyItemUpdateAction操作。在商店减速器中,我做了这样的事情:
const myItemToModifyIndex = state.myItems.findIndex(...predicated based on the passed a ction...)
// cloning the item that I need to modify.
const myItemClone = [...state.myItems[myItemToModifyIndex]];
// modifying properties on the cloned item using data from the action
myItemClone.interestingProperty = action.newValueFromUser;
// cloning the array of items from the state.
const myItemsArrayClone = [...state.myItems];
// setting new item in the cloned array.
myItemsArrayClone[myItemToModifyIndex] = myItemClone;
// return of new state.
return { myItems: myItemsArrayClone }
问题:
因为正如您从减速器中看到的那样,我已经修改了状态并基本上创建了myItems数组的新实例和我已修改的项目的副本,所以Angular 异步管道会对存储中的更改做出反应并重新呈现我的组件列表。它本身会重新渲染AppMyItemDetailsCardComponent的所有实例,并导致显示组件详细信息的标志为 false,并且 UI 更改和详细信息面板被隐藏。
问题:
1) 这种模式是否有意义并符合 NGRX 的处理方式?(我是角度方面的 redux 新手)。
2) 我可以通过将显示详细信息面板的标志保留在商店内来解决此问题。基本上,我不会将按钮 (click)="displayDetails = !displayDetails"切换为布尔标志,而是调度一个动作,该动作将更改 MyItem 实例本身的标志,该实例将驱动详细信息面板的显示。这可以被认为是一个好的解决方案吗?
解决方案
redux、ngrx 和状态处理都是关于引用的。
如果您创建一个新的数组引用,则 Angular 会认为它是一个新列表并重新渲染所有内容。
但是,如果您更改数组中特定项目的引用,则 Angular 只会推送新的 [item]="myItem" 并导致单个我的应用项目卡更新。
这是一个非常小心地创建新状态树的问题,只更新必要的内容。
我还将 displayDetails 放在项目中,这样当您克隆状态更改并且不会被覆盖时,它将保持同步。
推荐阅读
- python - PySNMP:如何在同一个代理中实现 CommandResponder 和 NotificationOriginator?
- reactjs - 没有根据反应中的状态变化触发 UseEffect
- reactjs - 在 Github 上托管后,带有 React 的 Twilio Chat API 无法正常工作
- php - 将函数名称传递给其他函数并从 PHP 中的不同文件调用
- node.js - 使用 npx 运行包时访问 node_modules 中的文件
- javascript - 在javascript nodejs中展平和排序嵌套数组
- apache-spark - Spark Structured Streaming - 根据条件连接 2 个数据帧
- c# - 在 .net 5 上使用 mongodb 驱动程序时出现 System.PlatformNotSupportedException
- python - 同步两个独立进程Python的输出
- python-3.x - 具有固定字典键的 Python 函数返回类型提示