首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在子组件中克隆从父组件传递的对象- React Hooks

在子组件中克隆从父组件传递的对象- React Hooks
EN

Stack Overflow用户
提问于 2021-06-18 07:12:08
回答 1查看 40关注 0票数 1

我使用扩展运算符和useState来克隆从父组件传递的对象,但它返回一个空对象。任何帮助都将不胜感激。谢谢:)

代码语言:javascript
复制
const Parent = () =>{

  //I fetch data from my custom hook
  const {data} = useFetch(url)

  return(
    <Child data={data}/>
  )
}

代码语言:javascript
复制
const Child = ({data}) =>{
   const [copyData, setCopyData] = useState({...data});
   
   
   //it returns an empty object here
   const testing = () =>{
    console.log(copyData)
   }
   
   return(
    <button onClick={testing}>Testing</button>
   )
}

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-06-18 07:22:46

当您的组件第一次呈现fetch请求时,它还没有完成,因此数据将为空(使用const {data, loading} = useFetch(url);查看)

然后,您的子组件将使用该null来设置copyData的默认值,并且您永远不会更新它。

您需要添加一个useEffect,以便在每次数据更改时调用setCopyData。可能是这样的:

代码语言:javascript
复制
useEffect(() => {
  setCopyData({...data});
}, [data]);
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68027519

复制
相关文章

相似问题

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