- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是 React Redux 环境的新手,目前面临一个我难以理解的问题。
我制作了一个包含链接列表的页面。当我单击“添加链接”按钮时,我可以将链接添加到列表中,然后会出现一个带有表单的模式。
当我提交表单时,当我从 link.utils.js 触发 addLinkItem 方法时,新链接将添加到 firebase
我正在使用react-thunk在firebase添加成功时进行调度,这是一个更新我的链接状态的操作。
我的问题是,此时我的 prevState 已经有了我的 nextState 值,所以问题是我的组件 LiSTLink 没有用这个新状态刷新。
我希望我说得足够清楚
您可以找到此存储库的所有项目:https://github.com/FrancoisSilab/klaxoon-test-bookmarks/blob/master/README.md
const handleSubmit = event => {
event.preventDefault();
addLinkItem(inputValues);
};
add-link-modal.component.jsx
export const addLinkItem = (link) => {
return dispatch => {
// On obtient la référence de la collection links
const colRef = firestore.collection("links");
// On ajoute le nouveau linkItem comme nouveau document
colRef
.add(link)
.then(function(docRef) {
console.log("Document successfully written!");
link["id"] = docRef.id;
dispatch(addLinkItemAction(link));
dispatch(resetInput());
})
.catch(function(error) {
console.error("Error writing document: ", error);
});
};
};
links.utils.js
export const addLinkItemAction = (link) => ({
type: LinksActionsTypes.ADD_LINK,
payload: link
});
links.actions.js
const INITIAL_STATE = {
linksItems: []
};
const linkReducer = (state = INITIAL_STATE, action) => {
switch (action.type) {
case LinksActionsTypes.GET_LINKS:
return {
...state,
linksItems: action.payload
};
case LinksActionsTypes.ADD_LINK:
state.linksItems.push(action.payload);
return {
...state,
linksItems: state.linksItems
};
case LinksActionsTypes.DELETE_LINK:
return {
...state,
linksItems: deleteLinkItem(state.linksItems, action.payload)
};
default:
return state;
}
};
export default linkReducer;
links.reducer.jsx
最佳答案
问题是你正在改变状态。而不是插入旧数组:
state.linksItems.push(action.payload);
return {
...state,
linksItems: state.linksItems
};
...创建数组的副本并将其添加到该副本中。
const newLinkItems = [...state.linkItems, action.payload];
return {
...state,
linkItems: newLinkItems
}
关于javascript - Redux以前的状态已经有了新的状态值无法理解为什么,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58146160/
我是 firebase 的新手,我正在尝试分页查询。我喜欢有一个“下一个”和“上一个”按钮。我的下一个按钮工作正常,我的问题是单击上一个 引用:https://firebase.google.com/
抱歉,标题这么蹩脚,但我只是不知道该放什么,希望你能理解。另外,我不知道以前是否有人问过类似的问题,因为我不知道合适的关键字 - 因此也无法用谷歌搜索。 基本上...在查看preg_match_all
我想在 TFS 中 check out 一个检入文件的先前版本。我可以轻松获得特定文件的变更集 ID 列表,但无法弄清楚如何 checkout 以前的版本。 我目前的代码: var workspace
我想使用 @FunctionalInterface来 self 代码中的 Java 8,但我希望能够将生成的类文件与 Java 6 一起使用。我认为我应该将源版本设为 1.8 , 目标版本为 1.6
自从 versions 被删除以来,我一直无法找到安装以前版本软件的方法。命令并点击 Homebrew。我在 2008 Mac Pro (3,1) 上运行 macOS 10.14.3 (Mojave)
当我开始当前的项目时,App Store 中已经有一个应用程序。此应用程序仅适用于 iPhone。 我的第一个任务是测试和构建一个也可以在 iPod Touch 上运行的版本。 大约 3 周前,App
我在 GitHub 上有一个曾经是 fork 的 repo,但现在不是了,因为我已经删除了原始项目的任何痕迹并开始了一个同名的新项目。 但是,GitHub 仍然表示该项目是 fork 的。有什么方法可
我是一名优秀的程序员,十分优秀!