How to Handle UI State in Redux/React - Redux-UI?

后端 未结 1 1565
醉酒成梦
醉酒成梦 2021-01-16 03:39

I am researching into what is the best way to store the UI state, Should I use something like Redux-UI (https://github.com/tonyhb/redux-ui) to store/manage the UI state? or

1条回答
  •  感情败类
    2021-01-16 04:03

    Our team has spent some days on this. The reasons we want UI states, instead of putting those states to Redux's state tree, can be:

    1. Those UI states are only relevant to a very small number of components. But yet sometimes we need to share those states amongst them. For example, a Button to control a Modal, they both need to read/write the 'isModalOpen' state.

    2. Those states are not data, they are UI preference and it is fine to reset them to the default upon component unmount. Persisting them in the single Redux store sounds like polluting the state tree.

    We tried:

    1. Creating a separate redux state tree just for UI.
    2. Add a main branch, say 'state.UI' for all 'UI' states.

    However, all these involve having to use/implement custom middleware, actions and reducers. Hard.

    At the end, I made react-provide-state. It works really well. The only drawback of it is your can not easily see the ui states like states in Redux tree in browser console. And you can only update states through UI (user action event callbacks). That's fair, it is UI states we are talking about.

    0 讨论(0)
提交回复
热议问题