mirror of
https://github.com/terribleplan/next.js.git
synced 2024-01-19 02:48:18 +00:00
22776c2eee
* Immplement the initial singleton Router. * Use the new SingletonRouter for HMR error handling. * Use SingletonRouter inside the Link. * Create an example app using the Router. * Make the url parameter optional in Router.push and Router.replace * Add a section about next/router in the README.
36 lines
836 B
JavaScript
36 lines
836 B
JavaScript
import { createElement } from 'react'
|
|
import { render } from 'react-dom'
|
|
import HeadManager from './head-manager'
|
|
import { rehydrate } from '../lib/css'
|
|
import { createRouter } from '../lib/router'
|
|
import App from '../lib/app'
|
|
import evalScript from '../lib/eval-script'
|
|
|
|
const {
|
|
__NEXT_DATA__: {
|
|
component,
|
|
errorComponent,
|
|
props,
|
|
ids,
|
|
err,
|
|
pathname,
|
|
query
|
|
}
|
|
} = window
|
|
|
|
const Component = evalScript(component).default
|
|
const ErrorComponent = evalScript(errorComponent).default
|
|
|
|
export const router = createRouter(pathname, query, {
|
|
Component,
|
|
ErrorComponent,
|
|
ctx: { err }
|
|
})
|
|
|
|
const headManager = new HeadManager()
|
|
const container = document.getElementById('__next')
|
|
const appProps = { Component, props, router, headManager }
|
|
|
|
if (ids) rehydrate(ids)
|
|
render(createElement(App, appProps), container)
|