記錄React性能優(yōu)化之“虛擬滾動(dòng)”技術(shù)——react-window

UI更新需要昂貴的 DOM 操作,而 React 內(nèi)部使用幾種巧妙的技術(shù)以便最小化 DOM 操作次數(shù)龟梦。對(duì)于大部分應(yīng)用而言,使用 React 時(shí)無(wú)需專門優(yōu)化就已擁有高性能的用戶界面朝刊。盡管如此陶衅,你仍然有辦法來(lái)加速你的 React 應(yīng)用久脯。

1. 虛擬化長(zhǎng)列表

如果你的應(yīng)用渲染了長(zhǎng)列表(上百甚至上千的數(shù)據(jù))時(shí)阅签,React官網(wǎng)推薦我們使用“虛擬滾動(dòng)”技術(shù)银室。這項(xiàng)技術(shù)會(huì)在有限的時(shí)間內(nèi)僅渲染有限的內(nèi)容鳄逾,并奇跡般地降低重新渲染組件消耗的時(shí)間稻轨,以及創(chuàng)建 DOM 節(jié)點(diǎn)的數(shù)量。

React官網(wǎng)推薦我們使用react-windowreact-virtualized 這2個(gè)熱門的虛擬滾動(dòng)庫(kù)雕凹。它們提供了多種可復(fù)用的組件殴俱,用于展示列表、網(wǎng)格和表格數(shù)據(jù)枚抵。

2. react-window與react-virtualized有什么不同线欲?

這2個(gè)庫(kù),出自于同一個(gè)作者汽摹。react-virtualized是作者對(duì)React和窗口概念都不熟悉時(shí)寫的李丰,加了一些API和添加了太多非必要的功能和組件,后來(lái)作者后悔了逼泣,但因?yàn)橐坏┫蜷_源項(xiàng)目添加了一些東西趴泌,刪除它對(duì)用戶來(lái)說(shuō)是非常痛苦的。所以作者完整重寫了react-virtualized拉庶,并且更專注于使包裝更小和更快嗜憔。所以react-window是react-virtualized的輕量級(jí)替代品。

3.使用react-window網(wǎng)格的問題和解決方案

我使用的是VariableSizeGrid(可變尺寸網(wǎng)格)砍的。

問題1:使用itemData進(jìn)行網(wǎng)格中數(shù)據(jù)的傳遞時(shí)痹筛,當(dāng)columnCount(網(wǎng)格中的列數(shù))*rowCount(網(wǎng)格中的行數(shù))>itemData.length,會(huì)出現(xiàn)網(wǎng)格滾動(dòng)到最后一行時(shí)廓鞠,最后一行沒有被渲染帚稠。

方案1:給itemData 數(shù)組push(columnCount*rowCount- itemData.length)個(gè)對(duì)象{true:true},然后在組件render時(shí)床佳,進(jìn)行判斷return(<div></div>)

問題2:網(wǎng)格可以100%填充頁(yè)面的寬度或高度嗎滋早?(這個(gè)問題作者有在npm上回答過)

方案2:網(wǎng)格寬高必須傳入number類型,所以不能直接寫’100%’砌们,需要使用react-virtualized-auto-sizer包杆麸。

問題3:這個(gè)比較重要搁进,沒有提供可以傳遞方法的API。提供了可以在外層附加自定義屬性或事件處理程序的API:outerElementType昔头。但不能滿足我想要點(diǎn)擊按鈕時(shí)才觸發(fā)事件的需求饼问。

方案3:JavaScript設(shè)計(jì)模式之觀察者模式

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市揭斧,隨后出現(xiàn)的幾起案子莱革,更是在濱河造成了極大的恐慌,老刑警劉巖讹开,帶你破解...
    沈念sama閱讀 216,591評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件盅视,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡旦万,警方通過查閱死者的電腦和手機(jī)闹击,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)成艘,“玉大人赏半,你說(shuō)我怎么就攤上這事∠剑” “怎么了除破?”我有些...
    開封第一講書人閱讀 162,823評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)琼腔。 經(jīng)常有香客問我瑰枫,道長(zhǎng),這世上最難降的妖魔是什么丹莲? 我笑而不...
    開封第一講書人閱讀 58,204評(píng)論 1 292
  • 正文 為了忘掉前任光坝,我火速辦了婚禮,結(jié)果婚禮上甥材,老公的妹妹穿的比我還像新娘盯另。我一直安慰自己,他們只是感情好洲赵,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,228評(píng)論 6 388
  • 文/花漫 我一把揭開白布鸳惯。 她就那樣靜靜地躺著,像睡著了一般叠萍。 火紅的嫁衣襯著肌膚如雪芝发。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,190評(píng)論 1 299
  • 那天苛谷,我揣著相機(jī)與錄音辅鲸,去河邊找鬼。 笑死腹殿,一個(gè)胖子當(dāng)著我的面吹牛独悴,可吹牛的內(nèi)容都是我干的例书。 我是一名探鬼主播,決...
    沈念sama閱讀 40,078評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼刻炒,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼决采!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起坟奥,我...
    開封第一講書人閱讀 38,923評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤织狐,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后筏勒,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,334評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡旺嬉,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,550評(píng)論 2 333
  • 正文 我和宋清朗相戀三年管行,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片邪媳。...
    茶點(diǎn)故事閱讀 39,727評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡捐顷,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出雨效,到底是詐尸還是另有隱情迅涮,我是刑警寧澤,帶...
    沈念sama閱讀 35,428評(píng)論 5 343
  • 正文 年R本政府宣布徽龟,位于F島的核電站叮姑,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏据悔。R本人自食惡果不足惜传透,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,022評(píng)論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望极颓。 院中可真熱鬧朱盐,春花似錦、人聲如沸菠隆。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,672評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)骇径。三九已至躯肌,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間破衔,已是汗流浹背羡榴。 一陣腳步聲響...
    開封第一講書人閱讀 32,826評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留运敢,地道東北人校仑。 一個(gè)月前我還...
    沈念sama閱讀 47,734評(píng)論 2 368
  • 正文 我出身青樓忠售,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親迄沫。 傳聞我的和親對(duì)象是個(gè)殘疾皇子稻扬,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,619評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容