learnyoureact
Version:
Learn React.js and server side rendering!
64 lines (50 loc) • 1.66 kB
JavaScript
var React = require('react');
var ReactDOMServer = require('react-dom/server');
var DOM = React.DOM;
var body = DOM.body;
var div = DOM.div;
var script = DOM.script;
var browserify = require('browserify');
var babelify = require("babelify");
var express = require('express');
var app = express();
app.set('port', (process.argv[2] || 3000));
app.set('view engine', 'jsx');
app.set('views', __dirname + '/views');
app.engine('jsx', require('express-react-views').createEngine());
require('babel/register')({
ignore: false
});
var TodoBox = require('./views/index.jsx');
var data = [
{title: 'Shopping', detail: process.argv[3]},
{title: 'Hair cut', detail: process.argv[4]}
];
app.use('/bundle.js', function (req, res) {
res.setHeader('content-type', 'application/javascript');
browserify({debug: true})
.transform(babelify.configure({
presets: ["react", "es2015"],
compact: false
}))
.require("prop_and_state/solution/app.js", {entry: true})
.bundle()
.pipe(res);
});
app.use('/', function (req, res) {
var initialData = JSON.stringify(data);
var markup = ReactDOMServer.renderToString(React.createElement(TodoBox, {data: data}));
res.setHeader('Content-Type', 'text/html');
var html = ReactDOMServer.renderToStaticMarkup(body(null,
div({id: 'app', dangerouslySetInnerHTML: {__html: markup}}),
script({
id: 'initial-data',
type: 'text/plain',
'data-json': initialData
}),
script({src: '/bundle.js'})
));
res.end(html);
});
app.listen(app.get('port'), function () {
});