0
を見つけることができなかった、それは言う:renderToStringが店
不変違反:「接続(ショー)の文脈や小道具のいずれかで「ストア」を見つけることができませんでした"ルートコンポーネントをaにラップするか、明示的に "ストア(store)"を "Connect(Show)"の小道具として渡します。
私は反応ヘルメットでアプリを実行しようとしています。
server.js
require('babel-core/register');
const renderToString = require('react-dom/server').renderToString;
var express = require('express');
const path = require('path');
const RouterContext = require('react-router').RouterContext;
const match = require('react-router').match;
const Router = require('react-router').Router;
const React = require('react');
const ReactDOM = require('react-dom');
const Helmet = require('react-helmet');
const routes = require('./src/routes');
console.log('1');
const port = process.env.PORT || 8080 ;
var app = express();
app.set('port', process.env.PORT || 8080);
app.use(express.static(__dirname));
app.get('*', (req, res) => {
match({routes: routes.default, location: req.url}, (err, redirectLocation, renderProps)=> {
console.log('2');
console.log(err);
if (err) {
return res.status(500).send(err.message);
}
if (redirectLocation) {
return res.redirect(302, redirectLocation.pathname + redirectLocation.search);
}
console.log('3');
let markup;
let rendered = renderToString(React.createElement(RouterContext , renderProps));
console.log('4');
let head = Helmet.rewind();
if (renderProps) {
markup = `
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8"/>
${head.title}
${head.meta}
${head.link}
</head>
<body>
<div id="app">
${rendered}
</div>
<script src="bundle.js"></script/>
</body>
</html>`
}
console.log('5');
res.write(markup);
res.end();
console.log('6');
});
});
app.listen(port);
console.log('Server started!');
routes.jsあなたはストアaを作成する必要が
import React from 'react';
import { Route, IndexRoute } from 'react-router';
import App from './components/app';
import Show from './components/show';
const routes = (
<Route path="/" component={App}>
<Route path="/:id" component={Show}/>
</Route>
);
export default routes;
のsrc/index.js
import React from 'react';
import ReactDOM from 'react-dom';
import { Provider } from 'react-redux';
import { createStore, applyMiddleware } from 'redux';
import { Router, browserHistory } from 'react-router';
import reducers from './reducers';
import routes from './routes';
import promise from 'redux-promise';
const createStoreWithMiddleware = applyMiddleware(promise)(createStore);
ReactDOM.render(
<Provider store={createStoreWithMiddleware(reducers)}>
<Router history={browserHistory} routes={routes} />
</Provider>
, document.querySelector('.container'));
ご協力ありがとう@qxz。 – user1666543