蓝狮注册React报错之组件不能作为JSX组件使用

总览
组件不能作为JSX组件使用,出现该错误有多个原因:

null
返回单个JSX元素
下面是一个错误如何发生的示例。

// App.tsx

// :no_entry:️ ‘App’ cannot be used as a JSX component.
// Its return type ‘Element[]’ is not a valid JSX element.
// Type ‘Element[]’ is missing the following properties from type ‘reactElement’: type, props, key
const App = () => {
return [‘a’, ‘b’, ‘c’].map(element => {
return

{element}

;
});
};

export default App;
代码示例中的问题是,我们返回的是一个JSX元素数组,蓝狮注册而不是单个JSX元素。

为了解决这种情况下的错误,我们必须使用 React fragment 或者 div 元素来包裹数组。

// App.tsx

const App = () => {
return (
<>
{[‘a’, ‘b’, ‘c’].map(element => {
return

{element}

;
})}

);
};

export default App;
现在我们的组件返回了单个JSX元素,这样错误就解决了。

当我们需要对子节点列表进行分组而不需要向dom中添加额外的节点时,就会使用Fragments。

您可能还会看到使用了更加详细的 fragments 语法。

// App.tsx

import React from ‘react’;

const App = () => {
return (
{[‘a’, ‘b’, ‘c’].map(element => { return

{element}

; })}
);
};

export default App;
你也可以使用div元素来充当包裹器,从组件中返回单个JSX元素。

不要忘记返回值
另一个常见原因是,我们从组件中返回JSX元素或者 null 以外的任意值,蓝狮官网或者忘记返回值。

// :no_entry:️ ‘App’ cannot be used as a JSX component.
// Its return type ‘undefined’ is not a valid JSX element.
const App = () => {
// :point_down:️ this returns undefined
return

hello world

};

export default App;
上述代码示例返回 undefined ,因为我们把返回语句放在一行,而把JSX代码放在下一行,并且没有使用括号。

我们不允许从组件中返回 undefined ,因此会出现这个错误。

为了解决该错误,我们必须确保返回的代码是可达的。

const App = () => {
return (

hello world

);
};

export default App;
如果你确信从React组件中,返回了单个JSX元素或者 null 。但是错误依旧存在,试着更新React类型声明。

更新React类型声明
在项目的根目录下打开终端,运行以下命令:

:point_down:️ with npm

npm install –save-dev @types/react@latest @types/react-dom@latest

:point_down:️ if you also want to update react and react-dom

npm install react@latest react-dom@latest

——————————

:point_down:️ with YARN

yarn add @types/react@latest @types/react-dom@latest –dev

:point_down:️ if you also want to update react and react-dom

yarn add react@latest react-dom@latest
该命令将会更新你的react类型声明版本。

确保重启开发服务器,如有必要请重启IDE。开发服务器不会接收这些更改,直到你停止它并重新运行 npm start 命令。

如果错误还没有被解决,尝试删除 node_modules 和 package-lock.json (不是 package.json )文件,重新运行 npm install ,重启IDE。

:point_down:️ delete node_modules and package-lock.json

rm -rf node_modules
rm -f package-lock.json
rm -f yarn.lock

:point_down:️ clean npm cache

npm cache clean –force

npm install
如果错误依旧存在,请确保重启了IDE和开发服务器。VSCode经常出现故障,有时重启就能解决问题。

0 Comments
Leave a Reply