首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Pass useState型

Pass useState型
EN

Stack Overflow用户
提问于 2022-03-16 23:10:23
回答 2查看 57关注 0票数 0

我有这样一个简单的应用程序

代码语言:javascript
复制
import React, { useState } from 'react'
import AddToList from './components/AddToList'
import List from './components/List'

export interface IProps{
  name: string
  age: number
  url: string
  note: string
}

const App = () => {

  const[people, setPeople] = useState([{
    name: 'chris',
    url: '',
    age: 21,
    note: 'note note'
  }])

  return (
    <div>
      <h2>People Invited</h2>
      <List people={people}/>
      <AddToList people setPeople/>
    </div>
  )
}

export default App

只是一个简单的useState,有一个对象和一个接口。

我有一个List组件来显示人中的对象。

我希望在AddToList中有一个表单来添加到人中。

我要把peoplesetPeople传给AddToList

代码语言:javascript
复制
import React from 'react'
import {IProps as Props} from '../App'

interface IProps{
    people: Props[]
    setPeople:any
}

const AddToList:React.FC<IProps> = ({people, setPeople}) => {
  return (
    <div>AddToList</div>
  )
}

export default AddToList    

在应用程序<AddToList people setPeople/>中,这里的人员是错误的,这是因为AddToList中的人员类型

代码语言:javascript
复制
interface IProps{
    people: Props[]
    setPeople:any
}

这里的类型应该是什么people: Props[]

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2022-03-16 23:44:15

代码语言:javascript
复制
<MyComponent foo />

其实只是以下几个词的缩写:

代码语言:javascript
复制
<MyComponent foo={true} />

这并不意味着:

代码语言:javascript
复制
<MyComponent foo={foo} />

如果你想通过这些道具,你要么需要:

代码语言:javascript
复制
<AddToList people={people} setPeople={setPeople} /> 

或者你可以把它们作为一个物体来传播:

代码语言:javascript
复制
<AddToList {...{ people, setPeople }} />

另外,react状态设置函数的正确类型是:

代码语言:javascript
复制
Dispatch<SetStateAction<T>>

其中T是您状态的类型。在这种情况下,将是:

代码语言:javascript
复制
interface IProps{
    people: Props[]
    setPeople: Dispatch<SetStateAction<Props[]>>
}
票数 2
EN

Stack Overflow用户

发布于 2022-03-16 23:29:20

我把台词从

<AddToList people setPeople/>

<AddToList people={people} setPeople={setPeople}/>和它为我工作。为我抛出的错误类型是类型"boolean“不能分配到输入Props[]。因此,当我做了这样的分配,它是有效的,但它可能会有所不同,根据您的打字稿版本。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/71505282

复制
相关文章

相似问题

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