redux-toolkit中,如何将state.transactions属性的旧对象与新对象合并
时间: 2024-02-26 20:56:40 浏览: 63
在Redux-Toolkit中,可以使用Immer库轻松地实现对象的合并。您可以使用`createSlice`函数的`reducers`字段来定义一个reducer,然后使用Immer库中的`produce`函数来修改状态。以下是一个示例代码:
```javascript
import { createSlice } from '@reduxjs/toolkit';
import produce from 'immer';
const transactionsSlice = createSlice({
name: 'transactions',
initialState: {
transactions: [],
},
reducers: {
mergeTransactions: (state, action) => {
const { oldTransaction, newTransaction } = action.payload;
state.transactions = produce(state.transactions, draftState => {
const oldIndex = draftState.findIndex(t => t.id === oldTransaction.id);
if (oldIndex !== -1) {
draftState[oldIndex] = { ...oldTransaction, ...newTransaction };
}
});
},
},
});
export const { mergeTransactions } = transactionsSlice.actions;
export default transactionsSlice.reducer;
```
在上面的代码中,我们定义了一个名为`mergeTransactions`的reducer,它接受一个包含旧事务和新事务的payload。我们使用Immer库中的`produce`函数来修改`state.transactions`数组,并使用`Array.findIndex`方法找到旧事务的索引。如果找到了旧事务,我们使用对象展开语法将旧事务与新事务合并,并将其设置为数组中的新对象。
您可以将这个reducer与其他reducer一起使用,以便在应用程序中对状态进行更改。例如,您可以在组件中调用`dispatch(mergeTransactions({ oldTransaction, newTransaction }))`来触发此reducer并合并旧对象和新对象。
阅读全文