reactjs - 为什么即使状态/依赖项发生了变化,应用程序也不会重新渲染
问题描述
我正在改变网格如下
const clearPath = () => {
grid.map((row) => {
row.map((node) => {
if (node.isVisited) {
//console.log(node);
node.isVisited = false;
}
});
});
setGrid(grid);
console.log(grid);
};
并将其渲染如下
return (
<div className="arena">
{grid.map((row, i) => (
<div key={i} className="row">
{row.map((node, j) => {
const { row, col, isStart, isEnd, isWall, isVisited } = node;
return (
<Node
key={j}
col={col}
row={row}
node={node}
isEnd={isEnd}
isStart={isStart}
isWall={isWall}
isVisited={isVisited}
mouseIsPressed={mouseIsPressed}
onMouseDown={(row, col) => {
handleMouseDown(row, col);
}}
onMouseEnter={(row, col) => {
handleMouseEnter(row, col);
}}
onMouseUp={() => handleMouseUp()}
></Node>
);
})}
</div>
))}
</div>
);
但是当我调用 clearPath 函数时,网格正在更新但应用程序没有重新渲染?为什么会这样?
解决方案
您正在改变旧数组而不是创建新数组。由于它们是引用相等的,因此反应从渲染中退出。由于数组是数组数组,因此您还需要映射它们,并复制更改的节点。
const clearPath = () => {
const newGrid = grid.map((row) => {
return row.map((node) => {
if (node.isVisited) {
return { ...node, isVisited: false };
}
return node;
});
});
setGrid(newGrid);
};
推荐阅读
- react-native - mediaQuery 在本机反应中不起作用
- android - Trying to start already running service in background thread
- php - 如何修复致命错误:无法重新声明 connectdb()
- python - 在tensorflow中初始化大小大于2GB的变量
- jquery - 从jQuery元素中获取最大的数据数
- python - 如何在 Jupyter Notebook 中打开 CSV 文件?
- android - 在android studio中调试子进程的本机代码
- reactjs - ES6 JS 摇树不适用于 antd lib
- php - SQL Prepared 语句未插入我的值
- swift - 如何在 swift 中使用卡片视图增加动态单元格高度