原文链接:https://bobbyhadz.com/blog/react-typescript-cannot-find-name[1]
作者:Borislav Hadzhiev[2]
正文从这开始~
.tsx扩展名
为了在React TypeScript中解决Cannot find name报错,我们需要在使用JSX
文件时使用.tsx
扩展名,在你的tsconfig.json
文件中把jsx
设置为react-jsx
,并确保为你的应用程序安装所有必要的@types
包。
typescript-react-cannot-find-name.webp
下面是在名为App.ts
的文件中发生错误的示例。
export default function App() {
// ⛔️ Cannot find name 'div'.ts(2304)
return (
<div>
<input type="text" id="message" value="Initial value" />
{/* Cannot find name 'button'.ts(2304) */}
<button>Click</button>
</div>
);
}
上述示例代码的问题在于,我们的文件扩展名为
.ts
,但是我们在里面却写的JSX
代码。
这是不被允许的,因此为了在TS文件中使用JSX,我们必须:
- 将文件命名为
.tsx
扩展名; - 在
tsconfig.json
中启用jsx
选项。
确保编写JSX代码的所有文件拥有.tsx
扩展名。
// App.tsx
export default function App() {
return (
<div>
<input type="text" id="message" value="Initial value" />
<button>Click</button>
</div>
);
}
如果在更新文件扩展名为.tsx
后,问题依然没有解决,请尝试重启IDE和开发服务器。
tsconfig.json配置文件
打开tsconfig.json
文件,确保jsx
选项设置为react-jsx
。
{
"compilerOptions": {
"jsx": "react-jsx", //