首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在反应中使用太多的useState钩子。我该怎么重构这个?

在反应中使用太多的useState钩子。我该怎么重构这个?
EN

Stack Overflow用户
提问于 2020-07-01 16:46:02
回答 1查看 6.5K关注 0票数 5

useState的钩子很棒。我主要使用useState挂钩来初始化某些状态,我还将函数传递给子组件以更改状态。然而,我意识到我开始在我的父页面组件中使用太多的useState挂钩。这看上去和感觉都不对,因为我开始在父页面组件中使用大约6-10 useState挂钩

在不显示代码的情况下,是否有更好的方法来做到这一点?也许是更好的练习,或者更好的改造方法。

谢谢

EN

回答 1

Stack Overflow用户

发布于 2021-02-01 09:27:16

每当遇到这样的问题时,您首先应该看看是否可以将组件拆分为多个较小的组件。然而,在某些情况下,这不是一种选择。在这些情况下,我建议使用useReducer。

代码语言:javascript
复制
// before

const {cache, setCache } = useState({});
const {posts, setPosts } = useState({});
const {loading, setLoading } = useState(false);

// Would become after refactor

const initialState = {
  cache: {},
  posts:{},
  loading: false
}

const [state, dispatch] = useReducer(reducer, initialState);
票数 10
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62681581

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档