【reactjs性能優(yōu)化】react-loadable 異步路由加載

優(yōu)勢

每個路由使用不同的chunk,沒必要一次加載所以js

配置插件 react-loadable

yarn add react-loadable -S

封裝高階組件

import React from 'react'
import Loadable from 'react-loadable'
import { isDevEnv } from '@/utils/env'

const Loading = (props) => {
  const { error } = props
  const isDev = isDevEnv
  if (error && isDev) {
    return (
      <div>
        <p>{error.stack ? error.stack : ''}</p>
      </div>
    )
  }
  return <div />
}

const loadableComponent = (loader, render) => {
  const config = {
    loader,
    loading: Loading,
    delay: 1000,
  }
  if (render) {
    config.render = render
  }
  return Loadable(config)
}

export default loadableComponent

使用方式

注意路由引入的方式使用 import的方式引入 const Stark = () => import('views/Stark')
使用 la高階組件包含 路由組件 component={la(Stark)}

import la from './loadableComponent'

const Stark = () => import('views/Stark')

<Switch>
    <Route path="/home" component={la(Stark)} key="home" exact />
</Switch>

打包后會產(chǎn)生很多 chunk

2019-07-08-15-32-59

每個路由使用不同的chunk,沒必要一次加載所以js

2019-07-08-15-38-45
2019-07-08-15-39-02
2019-07-08-15-39-23
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。