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:
parent
0a0bb2e673
commit
3e721b6878
|
@ -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)
|
||||||
|
|
|
@ -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>
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
})
|
})
|
||||||
|
|
Loading…
Reference in a new issue