gpt4 book ai didi

reactjs - 自定义 React `useFetch` Hook - 我需要维护多个状态吗?

转载 作者:行者123 更新时间:2023-12-03 13:43:49 27 4
gpt4 key购买 nike

我已经实现了一个自定义 useFetch Hook ,因此可以在我的应用程序中进行提取:

import { useEffect, useState } from 'react'

const useFetch = ({ url, defaultData = null }) => {
const [data, setData] = useState(defaultData)
const [loading, setLoading] = useState(true)
const [error, setError] = useState(null)

useEffect(() => {
fetch(url)
.then(res => res.json())
.then(res => {
setData(res)
setLoading(false)
})
.catch(err => {
setError(err)
setLoading(false)
})
}, [])

return [data, loading, error]
}

export default useFetch

然后我想到...这将在整个应用程序中使用。它如何知道哪个data/loading/error属于哪个调用?当我第一次使用 useFetch ,然后在应用程序中的其他地方紧随其后进行另一个使用时,React 是否跟踪哪些内部状态变量属于哪个钩子(Hook)调用?

然后我想也许我需要沿着 Redux 路线做更多的事情,并在 useReducer 钩子(Hook)的帮助下跟踪对自定义钩子(Hook)的所有调用:

import { useEffect, useReducer } from 'react'

const reducer = (state, action) => {
const { url, data, err } = action
const currentState = state[url]

switch (action.type) {
case 'fetching':
return { ...state, [url]: { ...currentState, loading: true } }
case 'success':
return { ...state, [url]: { ...currentState, loading: false, data } }
case 'fail':
return { ...state, [url]: { ...currentState, loading: false, err } }
default:
return state
}
}

const useFetch = ({ url, defaultData = null }) => {
const [state, dispatch] = useReducer(reducer, {}, { type: 'fetching', url })
const { data: d, loading: l, err: e } = state[url]

useEffect(() => {
fetch(url)
.then(res => res.json())
.then(data => dispatch({ type: 'success', url, data }))
.catch(err => dispatch({ type: 'fail', err }))
}, [])

return [d || defaultData, l, e]
}

export default useFetch

我是否需要像第二个示例一样手动跟踪对 useFetch 的所有调用?或者 React 是否在其内部处理这个问题,而第一个示例就是我所需要的?

最佳答案

每个自定义 Hook 都有自己的状态,并且不会在同一 Hook 的不同实例之间共享状态。因此,您不需要跟踪哪个状态属于哪个钩子(Hook)。

Hook 只会在不同实例之间共享逻辑,而不共享数据,就像 HOC 和 Render Props 一样。

所以第一个例子就可以正常工作了。

在您的情况下,多次调用 useFetch 实际上会导致多次调用 useStateReact FAQsuseState 解释状态的独立性,这确实回答了你的疑问

React keeps track of the currently rendering component. Thanks to the Rules of Hooks, we know that Hooks are only called from React components (or custom Hooks — which are also only called from React components).

There is an internal list of “memory cells” associated with each component. They’re just JavaScript objects where we can put some data. When you call a Hook like useState(), it reads the current cell (or initializes it during the first render), and then moves the pointer to the next one. This is how multiple useState() calls each get independent local state.

关于reactjs - 自定义 React `useFetch` Hook - 我需要维护多个状态吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53382115/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com