React / Express - 'Unexpected token <' в вызове renderToString()
Я работаю над настройкой рендеринга на стороне сервера для моего приложения React / Express, но я сталкиваюсь с синтаксической ошибкой, связанной с вызовом react-dom/server renderToString() Метод. Я свободно следую этому учебнику - http://crypt.codemancers.com/posts/2016-09-16-react-server-side-rendering/
index.js (Express app root):
'use strict'
require('babel-register')({
presets: ['es2015', 'react']
});
const express = require('express')
const path = require('path')
const app = express()
const React = require('react')
const reactDomServer = require('react-dom/server')
const routes = require('./src/routes.jsx')
const reactRouter = require('react-router')
let { match, RouterContext } = reactRouter
app.get('*', (req, res) => {
match({ routes: routes, location: req.url }, (err, redirect, props) => {
const appHtml = reactDomServer.renderToString(<RouterContext {...props}/>)
res.send(renderPage(appHtml))
})
})
Однако это приводит к ошибке:
const appHtml = reactDomServer.renderToString(<RouterContext {...props}/>)
^
SyntaxError: Unexpected token <
Во всех подобных примерах, которые я видел, есть прямой компонент JSX... что я пропал?
2 ответов:
babel-registerне обрабатывает файл, из которого он вызывается, см. https://stackoverflow.com/a/29425761/1795821Вам нужно будет поставить apt.get() вызывается в другой файл или используется другой метод загрузки Babel.
Так что создайте новый
renderReact.jsфайл сmodule.exports = function(app) { app.get('*', (req, res) => { match({ routes: routes, location: req.url }, (err, redirect, props) => { const appHtml = reactDomServer.renderToString(<RouterContext {...props}/>) res.send(renderPage(appHtml)) }) }) }Затем вернитесь в свой
index.jsСделайте это вместоlet renderReact = require('./renderReact.js'); renderReact(app);
Я считаю, что проблема связана с тем, что требование
babel-registerбудет работать не для файла, в который вы его импортируете, а для файлов, которые импортируются впоследствии. Таким образом, синтаксис JSX<RouterContextне будет подобран методомrenderToString. Это случалось со мной и раньше, включаяbabel-register, поскольку синтаксис никогда не казался мне чистым.То, что я лично сделал, и многие другие делают так:
readDomServer.renderToString(React.createElement(RoutingContext, props))используя методcreateElementв React, вы можете сделать то же самое. Это решит вашу проблему.
Comments