gpt4 book ai didi

javascript - 是否可以在 React Typescript 中将组件 prop 接口(interface)与另一个 prop 一起使用?

转载 作者:搜寻专家 更新时间:2023-10-30 21:07:37 25 4
gpt4 key购买 nike

基本上,我希望 injectComponentProps: object 行动态绑定(bind)到 injectComponent 的 prop 接口(interface)。在本例中,它将是 injectComponentProps: InjectedComponentProps,但我希望它是动态的。

I.e 一旦在 中设置了 injectComponent Prop ,injectComponentProps 就被定义为任何 injectComponent 的组件 Prop 。

这可能吗?

interface InjectedComponentProps {
variant: string
size: number
}

const InjectedComponent: React.FC<InjectedComponentProps> = (props) => {
return <Text {...props}>hello</Text>
}

interface ComponentProps {
injectComponent: React.ReactType
injectComponentProps: object
}

const Component: React.FC<ComponentProps> = (props) => {
const InjectedComponent = props.injectComponent
return (
<>
<InjectedComponent {...props.injectComponentProps}/>
</>
)
}


const Main: React.FC = () => {
return (
<Component
injectComponent={InjectedComponent}
injectComponentProps={{ variant: 'footnote', size: 14 }}
/>
)
}

最佳答案

interface InjectedComponentProps {
variant: string
size: number
}

const InjectedComponent: React.FC<InjectedComponentProps> = (props) => {
return null
}

interface ComponentProps<T> {
injectComponent: React.FC<T>
injectComponentProps: T
}

const Component = <T extends {}>(props: ComponentProps<T>): JSX.Element => {
const InjectedComponent = props.injectComponent
return (
<>
<InjectedComponent {...props.injectComponentProps}/>
</>
)
}


const Main: React.FC = () => {
return (
<Component
injectComponent={InjectedComponent}
injectComponentProps={{ variant: 'footnote', size: 14 }}
/>
)
}

关于javascript - 是否可以在 React Typescript 中将组件 prop 接口(interface)与另一个 prop 一起使用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57515055/

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