react列表渲染時(shí)為什么盡量不要把索引設(shè)置為key值

在react中者甲,如果要渲染一個(gè)列表商佛,我們會(huì)用map()函數(shù)將數(shù)組循環(huán)處理然后渲染到DOM,在處理循環(huán)時(shí)整葡,“key” 是一個(gè)你需要包含的特殊字符串屬性件余。

很多時(shí)候,我們會(huì)使用當(dāng)前列表的索引為key,但這樣做真的好嗎?

要討論這個(gè)問題蛾扇,我們要從react的原理說起搏明,我們r(jià)eact的執(zhí)行步驟一般是:用state和jsx模板生成虛擬DOM创千,然后用虛擬DOM生成真實(shí)的 DOM,當(dāng)我們state發(fā)生變化時(shí),render函數(shù)執(zhí)行,生成新的 虛擬DOM谚鄙,然后比較新舊虛擬DOM的區(qū)別,找到區(qū)別疚鲤,然后直接操作DOM啸如,改變有區(qū)別的內(nèi)容,這樣比傳統(tǒng)的操作DOM成翩,極大的提升了性能觅捆。

再說虛擬DOM,虛擬DOM其實(shí)就是一個(gè)JS對(duì)象(['div',{class:'app'},'item']),虛擬DOM核心之一是diff算法麻敌,diff算法的核心之一是同層對(duì)比栅炒,如圖:


同層對(duì)比

如果在第一層div時(shí)就有出現(xiàn)區(qū)別,那么對(duì)比結(jié)束术羔,直接更新真實(shí)DOM中對(duì)應(yīng)的當(dāng)前節(jié)點(diǎn)赢赊,以此類推。级历。释移。

再說說key,假設(shè)我們?cè)趕tate中有一個(gè)列表[a,b,c],在遍歷渲染時(shí)用索引作為key,那么就是這樣:

a 0
b 1
c 2

如果我們執(zhí)行一個(gè)操作寥殖,點(diǎn)擊刪除數(shù)組中的a玩讳, 我們的列表就是[b,c],在遍歷渲染時(shí)仍然會(huì)用索引作為key,結(jié)果如下:

b 0
c 1
區(qū)別

如圖 嚼贡,我們?nèi)绻挥盟饕秊閗ey , 程序能快速的對(duì)比出差異熏纯,反之也能對(duì)出差異,但是必須對(duì)比整個(gè)虛擬DOM粤策,
這樣豆巨,程序仍然能正常執(zhí)行,只不過大大消耗了新舊虛擬DOM的對(duì)比的性能掐场,并可能導(dǎo)致組件狀態(tài)問題往扔。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市熊户,隨后出現(xiàn)的幾起案子萍膛,更是在濱河造成了極大的恐慌,老刑警劉巖嚷堡,帶你破解...
    沈念sama閱讀 219,039評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蝗罗,死亡現(xiàn)場(chǎng)離奇詭異艇棕,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)串塑,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,426評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門沼琉,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人桩匪,你說我怎么就攤上這事打瘪。” “怎么了傻昙?”我有些...
    開封第一講書人閱讀 165,417評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵闺骚,是天一觀的道長。 經(jīng)常有香客問我妆档,道長僻爽,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,868評(píng)論 1 295
  • 正文 為了忘掉前任贾惦,我火速辦了婚禮胸梆,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘须板。我一直安慰自己碰镜,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,892評(píng)論 6 392
  • 文/花漫 我一把揭開白布逼纸。 她就那樣靜靜地躺著洋措,像睡著了一般济蝉。 火紅的嫁衣襯著肌膚如雪杰刽。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,692評(píng)論 1 305
  • 那天王滤,我揣著相機(jī)與錄音贺嫂,去河邊找鬼。 笑死雁乡,一個(gè)胖子當(dāng)著我的面吹牛第喳,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播踱稍,決...
    沈念sama閱讀 40,416評(píng)論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼曲饱,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了珠月?” 一聲冷哼從身側(cè)響起扩淀,我...
    開封第一講書人閱讀 39,326評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎啤挎,沒想到半個(gè)月后驻谆,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,782評(píng)論 1 316
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,957評(píng)論 3 337
  • 正文 我和宋清朗相戀三年胜臊,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了勺卢。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,102評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡象对,死狀恐怖黑忱,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情织盼,我是刑警寧澤杨何,帶...
    沈念sama閱讀 35,790評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站沥邻,受9級(jí)特大地震影響危虱,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜唐全,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,442評(píng)論 3 331
  • 文/蒙蒙 一埃跷、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧邮利,春花似錦弥雹、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,996評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至方庭,卻和暖如春厕吉,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背械念。 一陣腳步聲響...
    開封第一講書人閱讀 33,113評(píng)論 1 272
  • 我被黑心中介騙來泰國打工头朱, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人龄减。 一個(gè)月前我還...
    沈念sama閱讀 48,332評(píng)論 3 373
  • 正文 我出身青樓项钮,卻偏偏與公主長得像,于是被迫代替她去往敵國和親希停。 傳聞我的和親對(duì)象是個(gè)殘疾皇子烁巫,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,044評(píng)論 2 355

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