次のエラーが発生します:
キャッチされないエラー: 不変違反: 要素タイプが無効です。文字列 (組み込みコンポーネントの場合) またはクラス/関数 (複合コンポーネントの場合) が期待されましたが、取得されたのはオブジェクトです。
これが私のコードです:
var React = require('react')
var ReactDOM = require('react-dom')
var Router = require('react-router')
var Route = Router.Route
var Link = Router.Link
var App = React.createClass({
render() {
return (
<div>
<h1>App</h1>
<ul>
<li><Link to="/about">About</Link></li>
</ul>
</div>
)
}
})
var About = require('./components/Home')
ReactDOM.render((
<Router>
<Route path="/" component={App}>
<Route path="about" component={About} />
</Route>
</Router>
), document.body)
私のHome.jsx
ファイル:
var React = require('react');
var RaisedButton = require('material-ui/lib/raised-button');
var Home = React.createClass({
render:function() {
return (
<RaisedButton label="Default" />
);
},
});
module.exports = Home;
ベストアンサー1
私の場合 ( Webpack を使用) 、違いは次の通りでした:
import {MyComponent} from '../components/xyz.js';
対
import MyComponent from '../components/xyz.js';
2 番目は機能しますが、1 番目はエラーを引き起こします。またはその逆です。