React 开发人员经常遇到错误“Uncaught Error: Invariant Violation:元素类型无效:需要字符串(对于内置组件)或类/函数(对于复合组件)但得到了:对象。”这个令人费解的错误源于传递给 React 组件的元素类型的问题。
考虑以下代码snippets:
main.js:
import React from 'react'; import ReactDOM from 'react-dom'; import Router from 'react-router'; import App from './components/App'; import About from './components/About'; ReactDOM.render(( <Router> <Route path="/" component={App}> <Route path="about" component={About} /> </Route> </Router> ), document.body);
About.jsx:
import React from 'react'; import RaisedButton from 'material-ui/lib/raised-button'; export default class About extends React.Component { render() { return ( <RaisedButton label="Default" /> ); } };
在这种情况下,错误是由差异引起的main.js 中 Home 组件的导入语句。使用 import {MyComponent} from '../components/xyz.js' 而不是 import MyComponent from '../components/xyz.js' 会导致错误。导入语法中的这种差异可能会导致 React 错误地解释导入的组件,从而导致“无效元素类型”错误。
要解决此问题,请确保正确的导入语法是用于组件。在 Webpack 环境中,这意味着使用:
import MyComponent from '../components/xyz.js';
此语法将组件作为默认导出导入,这是 React 组件的预期行为。
以上是为什么我在 React 中收到'Invariant Violation: Element type is invalid”错误?的详细内容。更多信息请关注PHP中文网其他相关文章!