如何在 React 中使用获取的数据设置状态
How to setState with fetched data in React
我需要 setState
使用从 redux store
获得的对象。问题是当我在我的组件中调用 setState
时,我得到 undefined
。关于如何使用获取的数据设置状态的默认值有什么想法吗?
这是我的组件:
import React, { useEffect, Fragment, useState } from 'react';
import { useSelector, useDispatch } from 'react-redux';
const contactDetails = useSelector((state) => state.contactDetails)
const upFields = contactDetails?.contact?.data?.fields
const [contact, setContact] = useState({
fields: upFields <---- this is returning undefined.. The name is correct, but maybe setState is running too fast?
})
console.log(contact) <---- this shows {fields: undefined}
console.log(upFields) <---- this console.logs just fine
所以,我最终将状态组件设置得更高,并将“upFields”传递给需要该状态的子组件。一旦进入子组件,我只是 运行 useEffect 和 setState 以及我需要的数据
您使用 useEffect()
并使用对象触发它
useEffect(()=>{
setContact(fetched_data)
}, [fetched_data]) // <-- data array will trigger every time this data change
您可以使用
在第一个组件安装时触发它
useEffect(()=>{
setContact(fetched_data)
}, []) // <-- empty array will only trigger once
我需要 setState
使用从 redux store
获得的对象。问题是当我在我的组件中调用 setState
时,我得到 undefined
。关于如何使用获取的数据设置状态的默认值有什么想法吗?
这是我的组件:
import React, { useEffect, Fragment, useState } from 'react';
import { useSelector, useDispatch } from 'react-redux';
const contactDetails = useSelector((state) => state.contactDetails)
const upFields = contactDetails?.contact?.data?.fields
const [contact, setContact] = useState({
fields: upFields <---- this is returning undefined.. The name is correct, but maybe setState is running too fast?
})
console.log(contact) <---- this shows {fields: undefined}
console.log(upFields) <---- this console.logs just fine
所以,我最终将状态组件设置得更高,并将“upFields”传递给需要该状态的子组件。一旦进入子组件,我只是 运行 useEffect 和 setState 以及我需要的数据
您使用 useEffect()
并使用对象触发它
useEffect(()=>{
setContact(fetched_data)
}, [fetched_data]) // <-- data array will trigger every time this data change
您可以使用
在第一个组件安装时触发它useEffect(()=>{
setContact(fetched_data)
}, []) // <-- empty array will only trigger once