React 開發人員經常遇到錯誤「Uncaught Error: Invariantt Error: Invariantt Error: Invariantt Error: Invariantt Error: Invariantt Violation:元素類型無效:需要字串(對於內建元件)或類別/函數(對於複合元件)但得到了:物件。
考慮以下程式碼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中文網其他相關文章!