javascript – 从redux中的reducer中获取ID

前端之家收集整理的这篇文章主要介绍了javascript – 从redux中的reducer中获取ID前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我很新,并尝试使用react& amp来构建一个简单的书签应用程序.终极版.

我无法解决这个问题:

用户可以创建一个书签并将其添加到多个文件夹.所以我发送一个addMark(书签)动作,然后发送addMark(文件夹)或editFolder(文件夹),如果该文件夹已存在.正如您所看到的,书签和文件夹是通过相同的操作添加的,因为在我的状态树中,它们都只是标记 – 由它们的类型属性区分.

我的问题:如何告诉文件夹对象哪个是新书签添加到书签的文件夹列表?如何在两个调度之间检索新创建的书签的ID?

解决方案我觉得不满意:

>我知道如何在reducer中生成书签ID(通过现有书签ID上的Math.max),因此我可以在2个调度之间重现新的书签ID.这听起来像是一个糟糕的黑客.
>书签和文件夹保存在同一个状态分支(相同的缩减器)中,因为它们都只是“标记”,我可以有一个引用最新添加的书签的状态属性,但这听起来也像是一个糟糕的黑客.

一点源代码,了解我所拥有的:

@H_301_18@// mapping between dispatcher and props to my react view const mapDispatchToProps = (dispatch) => ({ saveMark: (mark) => { if (mark.id) { dispatch(editMark(mark)); } else { dispatch(addMark(mark)); } },}); export default connect(mapStateToProps,mapDispatchToProps)(AddMark);

在AddMark中,它是容器组件:

@H_301_18@// save the bookmark first this.props.saveMark({ type: 'bookmark',title: this.state.title,url: this.state.url,icon: this.props.icon,style: this.state.style,}); // now I need the bookmark ID folders.forEach(folder => { folder.children.push(bookmarkID) // <-- !!! }); folders.forEach(folder => this.props.saveMark(folder));

我找不到令人满意的解决方案.

最佳答案
我认为你应该只在这里调度一个动作:addBookmark(),它接受书签对象和文件夹.

处理将书签对象添加文件夹中的代码应该是reducer的一部分.

另外,请参阅Redux项目中的Todos example.它在动作创建中提供了id,使其可以在组件中读取它.您还可以使用当前状态来计算最新ID:

@H_301_18@function addBookmark(bookmark,folder) { return (dispatch,getState) => { const newBookmark = Object.assign({ id: Math.max(0,...getState().bookmarks.map(b => b.id)) + 1,},bookmark); dispatch({ type: 'ADD_BOOKMARK',bookmark: newBookmark,folder: folder }); } }

请注意,该示例需要redux-thunk中间件来分派这些操作.

然后,您可以在文件夹reducer中访问带有id的书签

@H_301_18@function folderReducer(state = [],action) { if(action.type === 'ADD_BOOKMARK') { return state.map(folder => { if(folder === action.folder) { return Object.assign({},folder,{children: [...folder.children,action.bookmark.id]} } return folder; }) } //another reducer code return state; }

猜你在找的JavaScript相关文章