mirror of
https://github.com/terribleplan/next.js.git
synced 2024-01-19 02:48:18 +00:00
Implement ssr=false support.
This commit is contained in:
parent
f2bfcd01b0
commit
b5a03a3896
3
examples/with-dynamic-import/components/hello3.js
Normal file
3
examples/with-dynamic-import/components/hello3.js
Normal file
|
@ -0,0 +1,3 @@
|
|||
export default () => (
|
||||
<p>Hello World 3 (imported dynamiclly) </p>
|
||||
)
|
|
@ -10,12 +10,17 @@ const DynamicComponentWithCustomLoading = dynamic(
|
|||
loading: () => (<p>...</p>)
|
||||
}
|
||||
)
|
||||
const DynamicComponentWithNoSSR = dynamic(
|
||||
import('../components/hello3'),
|
||||
{ ssr: false }
|
||||
)
|
||||
|
||||
export default () => (
|
||||
<div>
|
||||
<Header />
|
||||
<DynamicComponent />
|
||||
<DynamicComponentWithCustomLoading />
|
||||
<DynamicComponentWithNoSSR />
|
||||
<p>HOME PAGE is here!</p>
|
||||
<Counter />
|
||||
</div>
|
||||
|
|
|
@ -6,11 +6,17 @@ export default function dynamicComponent (promise, options = {}) {
|
|||
return class Comp extends React.Component {
|
||||
constructor (...args) {
|
||||
super(...args)
|
||||
|
||||
this.LoadingComponent = options.loading ? options.loading : () => (<p>loading...</p>)
|
||||
this.ssr = options.ssr === false ? options.ssr : true
|
||||
|
||||
this.state = { AsyncComponent: null }
|
||||
this.isServer = typeof window === 'undefined'
|
||||
|
||||
if (this.ssr) {
|
||||
this.loadComponent()
|
||||
}
|
||||
}
|
||||
|
||||
loadComponent () {
|
||||
promise.then((AsyncComponent) => {
|
||||
|
@ -27,6 +33,9 @@ export default function dynamicComponent (promise, options = {}) {
|
|||
|
||||
componentDidMount () {
|
||||
this.mounted = true
|
||||
if (!this.ssr) {
|
||||
this.loadComponent()
|
||||
}
|
||||
}
|
||||
|
||||
render () {
|
||||
|
|
Loading…
Reference in a new issue