1
0
Fork 0
mirror of https://github.com/terribleplan/next.js.git synced 2024-01-19 02:48:18 +00:00

apply css on server rendering

This commit is contained in:
nkzawa 2016-10-09 18:50:41 +09:00
parent 0a0bb2e673
commit 3e721b6878
3 changed files with 10 additions and 4 deletions

View file

@ -1,12 +1,13 @@
import { createElement } from 'react' import { createElement } from 'react'
import { render } from 'react-dom' import { render } from 'react-dom'
import HeadManager from './head-manager' import HeadManager from './head-manager'
import { StyleSheet } from '../lib/css'
import Router from '../lib/router' import Router from '../lib/router'
import DefaultApp from '../lib/app' import DefaultApp from '../lib/app'
import evalScript from '../lib/eval-script' import evalScript from '../lib/eval-script'
const { const {
__NEXT_DATA__: { app, component, props } __NEXT_DATA__: { app, component, props, classNames }
} = window } = window
const App = app ? evalScript(app).default : DefaultApp const App = app ? evalScript(app).default : DefaultApp
@ -17,4 +18,5 @@ const headManager = new HeadManager()
const container = document.getElementById('__next') const container = document.getElementById('__next')
const appProps = { Component, props, router, headManager } const appProps = { Component, props, router, headManager }
StyleSheet.rehydrate(classNames)
render(createElement(App, { ...appProps }), container) render(createElement(App, { ...appProps }), container)

View file

@ -30,7 +30,7 @@ export function Head (props, context) {
.map((h, i) => React.cloneElement(h, { key: '_next' + i })) .map((h, i) => React.cloneElement(h, { key: '_next' + i }))
return <head> return <head>
{h} {h}
<style data-aphrodite>{css.content}</style> <style data-aphrodite dangerouslySetInnerHTML={{ __html: css.content }} />
</head> </head>
} }
@ -40,7 +40,7 @@ export function Main (props, context) {
const { html, data } = context._documentProps; const { html, data } = context._documentProps;
return <div> return <div>
<div id='__next' dangerouslySetInnerHTML={{ __html: html }} /> <div id='__next' dangerouslySetInnerHTML={{ __html: html }} />
<script dangerouslySetInnerHTML={{ __html: '__NEXT_DATA__ = ' + htmlescape(data) }}></script> <script dangerouslySetInnerHTML={{ __html: '__NEXT_DATA__ = ' + htmlescape(data) }} />
</div> </div>
} }

View file

@ -34,7 +34,11 @@ export async function render (path, ctx, { dir = process.cwd(), dev = false } =
html, html,
head, head,
css, css,
data: { component, props }, data: {
component,
props,
classNames: css.renderedClassNames
},
hotReload: false, hotReload: false,
dev dev
}) })