我收到“React.Children.only 希望收到单个 React 元素子元素。”从下面的代码。
我使用 create-react-app 创建了一个新的 React 应用程序,并安装了 redux 和 react-redux,并创建了一个简单的减速器并用它创建了商店。
import React from "react";
import ReactDOM from "react-dom";
import { createStore, combineReducers } from "redux";
import { Provider } from "react-redux";
import logo from './logo.svg';
import './App.css';
class App extends React.Component {
render() {
return (
<div className="App">
<div className="App-header">
<img src={logo} className="App-logo" alt="logo" />
<h2>Welcome to React</h2>
</div>
<p className="App-intro">
To get started, edit <code>src/App.js</code> and save to reload.
</p>
</div>
);
}
}
function productReducer(state = [], action) {
return state;
}
const store = createStore(
productReducer
);
ReactDOM.render((<Provider store={store}><App /> </Provider>), document.getElementById('root'));
您在这里有一个空间:
↓
<Provider store={store}><App /> </Provider>
JSX 对单行间距有点挑剔。上面的内容基本上被解释为:
<Provider store={store}><App />{' '}</Provider>
(实际上,Prettier https://prettier.io/将产生几乎就是这个确切的输出 https://prettier.io/playground/#N4Igxg9gdgLgprEAuc0DOMAEBBADrzAXkwAoBKIgPlIB0oaYAeABQCcIA3ASwBM5XKjPAQD01RiLade-SnTIBuEABoQEXDC7pkoAIat2Ad2b6EaZCF0cIvFSABGrXWADWcGAGVczrlADmyDCsAK5wqgAWMAC2ADYA6uFc8GjeYHAeZklc3DAAnhZgaOaqvmj8MGy6flG6yABmujFlqgBWaAAeAEJOru4eulFwADK+cPWNzSBt7R6+fjFwAIrBEPDjTWEg3qxlrBb2uvZwMXa4rL4wcbww4cgAHAAMqmcQZXFOuBZncLscY6oARxW8CkuHMKF0aAAtFA4HA+Dw7Kw4ECuMjKtVakgGhtVGUolxAiFNmg5gtlqsxtiJpsYIcrjwbsgAEyqIK6LgxOYAYQgURqFig0H+IGCZQAKodwTiygBfWVAA)
您可以删除空格:
<Provider store={store}><App /></Provider>
或者将其分成多行:
<Provider store={store}>
<App />
</Provider>
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)