gpt4 book ai didi

reactjs - 不能将 React Icons 组件用作对象值 typescript

转载 作者:行者123 更新时间:2023-12-05 02:39:04 35 4
gpt4 key购买 nike

我正在使用 typescript 和 react 开发一个个人网站,对于我的页脚,我正在映射一组对象,每个对象都有一个 url 属性和一个 icon 属性。 Icon 属性应该有多个不同的 React Icons 作为值,这样通过每次迭代,我可以显示一个不同的 Icon。当我最初用 javascript 实现它时,我的代码工作得很好,但是在将我的代码库切换到 typescript 之后,我遇到了这个错误:

"Parsing error: '>' expected.eslint'FaGithub' refers to a value, but is being used as a type here. Did you mean 'typeof FaGithub'?ts(2749)"

这是我到目前为止的 typescript 实现。我试过删除尖括号,这消除了错误,但在通过数组映射时我无法实际显示图标。如果有任何建议,我将不胜感激。

const socialIcons: { icon: IconType, url: string }[] = [
{
icon: <FaGithub />,
url: "./"
},
{
icon: <FaLinkedin />,
url: "./"
},
{
icon: <FaTwitter />,
url: "./"
},
{
icon: <FaInstagram />,
url: "./"
},
{
icon: <FaFacebook />,
url: "./"
},
]
{socialIcons.map((icons, index) => {
const {icon, url} = icons;
return (
<a href={url} key={index} target="_blank" rel="noopener noreferrer">
{icon}
</a>
);
})}

这是 socialIcons 数组最初在常规 javascript 中的样子。

const socialIcons = [
{
icon: <FaGithub />,
url: "./"
},
{
icon: <FaLinkedin />,
url: "./"
},
{
icon: <FaTwitter />,
url: "./"
},
{
icon: <FaInstagram />,
url: "./"
},
{
icon: <FaFacebook />,
url: "./"
},
]

最佳答案

我想出了一个解决方案,我需要做的就是将文件扩展名从 .ts 更改为 .tsx,并将值的类型设为 JSX.Element 以将 react 组件作为对象中的值输入,而不会出现 typescript 编译器错误.

关于reactjs - 不能将 React Icons 组件用作对象值 typescript ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69248594/

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