我有以下简单的 React 组件:
export interface BadgeProps {
children: React.ReactNode | string | React.ReactNode[],
layout: "gray" | "danger" | "success" | "brand",
size?: "sm" | "base",
}
const Badge: React.FC<BadgeProps> = ({ children }) => {
return (
<div data-test="component-badge">{children}</div>
);
}
当我现在以这种方式调用组件时,它可以正常工作:
<Badge layout="gray">Text</Badge>
但是当我使用扩展运算符传递道具时,出现以下错误。
const props = { layout: "gray" };
return (
<Badge {...props}>Text</Badge>
);
类型“字符串”不可分配给类型“灰色”| “危险” | “成功” | “牌”'
我觉得它应该可以正常工作,但我不知道它为什么会失败。这是对 Typescript 工作原理的误解吗?