react異步加載組件與代碼分割

繼續(xù)學(xué)習(xí)github高贊項目react-pxq

項目router中引入了路由組件,使用了異步加載的模式

import asyncComponent from '@/utils/asyncComponent';

const record = asyncComponent(() => import("@/pages/record/record"));
const helpcenter = asyncComponent(() => import("@/pages/helpcenter/helpcenter"));
const production = asyncComponent(() => import("@/pages/production/production"));
const balance = asyncComponent(() => import("@/pages/balance/balance"));

異步加載組件后腌歉,打包后項目文件多了幾個chunk.js。


圖片.png

這些js文件在打開項目時并未加載齐苛,直到點擊了相應(yīng)路由后才進行加載翘盖。
asyncComponent 函數(shù)的實現(xiàn)方式發(fā)現(xiàn)有很多“挤洌看了一些后發(fā)現(xiàn)還是項目中的最簡潔馍驯。

export default function asyncComponent(importComponent) {
  class AsyncComponent extends Component {
    constructor(props) {
      super(props);

      this.state = {
        component: null
      };
    }

    async componentDidMount() {
      const { default: component } = await importComponent();

      this.setState({component});
    }

    render() {
      const C = this.state.component;

      return C ? <C {...this.props} /> : null;
    }
  }

  return AsyncComponent;
}

發(fā)現(xiàn)函數(shù)中寫了一個組件類,其生命周期函數(shù)componentDidMount加了es2017的async玛痊。
原理是在需要的路由組件外包裹了一層AsyncComponent 組件汰瘫,當AsyncComponent 組件渲染時,觸發(fā)componentDidMount生命周期擂煞,componentDidMount生命周期中修改了state混弥,導(dǎo)致render再次執(zhí)行。而state中存儲了需要加載的路由組件对省,在render中返回蝗拿,觸發(fā)渲染。
在組件樹中可見非異步組件直接在Route下


圖片.png

而異步加載的組件會包裹在AsyncComponent中官辽。
圖片.png

看完項目的小小功能點后蛹磺,順便復(fù)習(xí)了下webpack打包中的chunkFilename
chunkFilename: 'static/js/[name].[chunkhash:8].chunk.js',

該配置控制著chunk文件的文件名,如上圖在使用異步加載組件后多出的4個文件同仆。

學(xué)完這個后發(fā)現(xiàn)官網(wǎng)上有異步加載和代碼分割的方案react.lazy Suspense萤捆。
為react16.6加入,方法更加優(yōu)雅俗批。Suspense的fallback 屬性可設(shè)置組件切換之間的短暫空白頁面俗或,如顯示loading

import React, { Suspense } from 'react';

const OtherComponent = React.lazy(() => import('./OtherComponent'));
const AnotherComponent = React.lazy(() => import('./AnotherComponent'));

function MyComponent() {
  return (
    <div>
      <Suspense fallback={<div>Loading...</div>}>
        <section>
          <OtherComponent />
          <AnotherComponent />
        </section>
      </Suspense>
    </div>
  );
}

下次再拜讀源碼

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市岁忘,隨后出現(xiàn)的幾起案子辛慰,更是在濱河造成了極大的恐慌,老刑警劉巖干像,帶你破解...
    沈念sama閱讀 217,734評論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件帅腌,死亡現(xiàn)場離奇詭異驰弄,居然都是意外死亡,警方通過查閱死者的電腦和手機速客,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,931評論 3 394
  • 文/潘曉璐 我一進店門戚篙,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人溺职,你說我怎么就攤上這事岔擂。” “怎么了浪耘?”我有些...
    開封第一講書人閱讀 164,133評論 0 354
  • 文/不壞的土叔 我叫張陵乱灵,是天一觀的道長。 經(jīng)常有香客問我七冲,道長痛倚,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,532評論 1 293
  • 正文 為了忘掉前任癞埠,我火速辦了婚禮状原,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘苗踪。我一直安慰自己,他們只是感情好削锰,可當我...
    茶點故事閱讀 67,585評論 6 392
  • 文/花漫 我一把揭開白布通铲。 她就那樣靜靜地躺著,像睡著了一般器贩。 火紅的嫁衣襯著肌膚如雪颅夺。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,462評論 1 302
  • 那天蛹稍,我揣著相機與錄音吧黄,去河邊找鬼。 笑死唆姐,一個胖子當著我的面吹牛拗慨,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播奉芦,決...
    沈念sama閱讀 40,262評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼赵抢,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了声功?” 一聲冷哼從身側(cè)響起烦却,我...
    開封第一講書人閱讀 39,153評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎先巴,沒想到半個月后其爵,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體冒冬,經(jīng)...
    沈念sama閱讀 45,587評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,792評論 3 336
  • 正文 我和宋清朗相戀三年摩渺,在試婚紗的時候發(fā)現(xiàn)自己被綠了简烤。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,919評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡证逻,死狀恐怖乐埠,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情囚企,我是刑警寧澤丈咐,帶...
    沈念sama閱讀 35,635評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站龙宏,受9級特大地震影響棵逊,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜银酗,卻給世界環(huán)境...
    茶點故事閱讀 41,237評論 3 329
  • 文/蒙蒙 一辆影、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧黍特,春花似錦蛙讥、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,855評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至翔曲,卻和暖如春迫像,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背瞳遍。 一陣腳步聲響...
    開封第一講書人閱讀 32,983評論 1 269
  • 我被黑心中介騙來泰國打工闻妓, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人掠械。 一個月前我還...
    沈念sama閱讀 48,048評論 3 370
  • 正文 我出身青樓由缆,卻偏偏與公主長得像,于是被迫代替她去往敵國和親份蝴。 傳聞我的和親對象是個殘疾皇子犁功,可洞房花燭夜當晚...
    茶點故事閱讀 44,864評論 2 354