Gat*_*oyu 11 reactjs react-hooks
我想要一个控制 select 的钩子,但它的初始状态可以通过 url 和 api 调用来定义。
这是我想要实现的行为:
这是我尝试过的(当然它不起作用):
const match = useRouteMatch('/document/:id') //react-router
const result = useAsync(api.getDocuments, []) //react-use
const [selectIndex, setSelectIndex] = useState(match && !(result.loading || result.error) && result.value.documents.findIndex(({_id}) => _id === match.params.id))
Run Code Online (Sandbox Code Playgroud)
基本上我想要一个用于 useState 的异步初始状态
我觉得 useEffect 可能有用,但我仍然不知道如何使用它
使用 useEffect 和 useState 的组合来异步初始化一个值,您可以在 ui 上更改该值。
import { useEffect, useState } from 'react'
import { useRouteMatch } from 'react-router-dom'
const App = () => {
const [value, setValue] = useState()
const { params } = useRouteMatch('/document/:id')
useEffect(() => {
someAsyncStuff(params.id).then(data => setValue(data))
}, [params])
return (
<select
value={value}
onChange={({target: { value }}) => setValue(value)}>
<option value={1}>one</option>
<option value={2}>two</option>
</select>
)
}
Run Code Online (Sandbox Code Playgroud)
顺便提一下,在 2022 年,如果您使用一些允许顶级等待的捆绑器,您可以读取组件外部的异步值,因此
import { useEffect, useState } from 'react'
const someValue = await getSomeValue();//<=this
const App = () => {
const [value, setValue] = useState(someValue)
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
9415 次 |
| 最近记录: |