2017-06-03 17 views
2

私はサーバーサイドレンダリングを設定したアプリケーションを持っています。すべてがうまくいき、コンポーネントがサーバー上でレンダリングされます。問題は、コンポーネントを画面上に2回レンダリングすることです。 1つはサーバレンダリングに使用している<div id="content"><%- content %></div>から来ており、1つは<script src="http://localhost:3001/bundle.js"></script>から来ています。私はwebpackを使って自分のサーバーとクライアント用に2つのバンドルを作成します。なぜこれが起こっているのですか?これをどのように修正できますか?リアクションコンポーネントがサーバーサイドレンダリングを使用して2回レンダされる

ビュー/ index.ejs

<body> 
    <div id="app"></div> 
    <div id="content"><%- content %></div> 
    <script src="http://localhost:3001/bundle.js"></script> 
</body> 

index.js

app.use(Express.static(path.join(__dirname, '../', 'dist'))) 

app.use(serverRenderer) 
app.get('*', (req: Object, res: Object) => { 
    res.render('index', {content: req.body}) 
}) 

serverRender

import React from 'react' 
import ReactDOM from 'react-dom/server' 
import { match, RouterContext } from 'react-router' 
import routes from '../client/routes.js' 

async function render (component) { 
    const content = ReactDOM.renderToString(component) 
    return content 
} 

async function getMatchParams (routes, currentUrl) { 
    return new Promise((resolve, reject) => { 
    match({routes: routes, location: currentUrl}, (err, redirect, props) => { 
     if (err) { 
     return reject(err) 
     } 
     return resolve(props) 
    }) 
    }) 
} 

export default async(req, res, next) => { 
    const renderProps = await getMatchParams(routes, req.url) 
    if (renderProps) { 
    const component = (
     <RouterContext {...renderProps} /> 
    ) 
    req.body = await render(component) 
    next() 
    } 
} 

答えて

0

[OK]をクリックします。私は問題を見つけました。私はバンドルとサーバーを2つの別の<div>とレンダリング文字列を参照していた。私app.js内部で私は、このようなテンプレートに文字列を送信されている必要がありますなぜこの

render(
    <Router history={browserHistory}> 
     {routes} 
    </Router>, 
    document.getElementById('app') 
) 

ザッツをしていました。

app.use(Express.static(path.join(__dirname, '../', 'dist'))) 

app.use(serverRenderer) 
app.get('*', (req: Object, res: Object) => { 
    res.render('index', {app: req.body}) 
}) 

そして最後に、私のビュー/ index.jsこの

<body> 
    <div id="app"><%- app %></div> 
    <script src="http://localhost:3001/bundle.js"></script> 
</body> 
のようになります。
関連する問題