首页
学习
活动
专区
圈层
工具
发布

React.FC属
EN

Stack Overflow用户
提问于 2020-11-15 10:07:26
回答 1查看 118关注 0票数 0

我正在尝试构建组件,它要么返回路由器链接,要么提供按钮,这取决于道具。这是我的代码:

代码语言:javascript
复制
import React from 'react';
import Button from '@material-ui/core/Button';
import { Link } from 'react-router-dom';

type OwnProps = { url: string } | { onClick: () => void };

const NavButton: React.FC<OwnProps> = ({ url, onClick, children }) => (
  <Button component={url ? Link : undefined} to={url} onClick={onClick}>
    {children}
  </Button>
);

export default NavButton;

但是,我收到一个错误,它说:

TS2339:属性'url‘在'PropsWithChildren’类型上不存在。TS2339:属性'onClick‘在'PropsWithChildren’类型上不存在。

P.S.:我不希望两个道具都包含在界面中。我想要这个还是那个。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-11-15 12:18:30

您可以这样键入OwnProps

代码语言:javascript
复制
{ url: string, onClick?: never } | { url?: never, onClick: () => void }
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64843169

复制
相关文章

相似问题

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