VUE中key的作用和原理

<!DOCTYPE html>
<html>
<head>
<title>03-key的作用及原理</title>
</head>
<body>
  <div id="demo">
    <p v-for="item in items" :key="item">{{item}}</p>
  </div>
<script src="../../dist/vue.js"></script>
<script>
// 創(chuàng)建實(shí)例
const app = new Vue({
  el: '#demo',
  data: { items: ['a', 'b', 'c', 'd', 'e'] },
  mounted () {
    setTimeout(() => {
      this.items.splice(2, 0, 'f')
    }, 2000);
  }
});
</script>
</body>
</html>

上面過(guò)程的圖畫重現(xiàn)


插入過(guò)程.jpg

如果不使用key,則每一項(xiàng)都需要強(qiáng)制更新弟断,在創(chuàng)建最后一項(xiàng)


不使用key過(guò)程.jpg

若使用key循環(huán)舊數(shù)組多搀,當(dāng)發(fā)現(xiàn)舊開(kāi)始節(jié)點(diǎn)與新開(kāi)始節(jié)點(diǎn)的key不相等時(shí),patch舊節(jié)點(diǎn)與新節(jié)點(diǎn)最后一項(xiàng)喜鼓,過(guò)程如下
1际乘、patch A

舊數(shù)組:a b c d e
新數(shù)組:a b f c d e

2坡倔、patch B

舊數(shù)組:b c d e
新數(shù)組:b f c d e

3、patch E

舊數(shù)組:c d e
新數(shù)組:f c d e

4脖含、patch D

舊數(shù)組:c d
新數(shù)組:f c d

5罪塔、patch C

舊數(shù)組:a b c d e
新數(shù)組:a b f c d e

6、舊節(jié)點(diǎn)全部處理完畢养葵,新節(jié)點(diǎn)只剩下f征堪,就會(huì)把f插入到c前面即可。

不使用key和使用Key比較关拒,前者是更新C->F佃蚜、D->C、 E->D三次着绊,插入E;后者是只進(jìn)行了插入F的操作谐算,在數(shù)據(jù)量大的時(shí)候,性能優(yōu)化的效果顯而易見(jiàn)畔柔。

結(jié)論

1氯夷、key的作用是為了高效更新虛擬DOM,原理是在源碼patch.js的patchVnode過(guò)程中靶擦,會(huì)觸發(fā)updateChildren()方法中可以通過(guò)key精準(zhǔn)判斷節(jié)點(diǎn)是否是同一節(jié)點(diǎn)腮考,從而避免頻繁更新不同元素,使得整個(gè)patch過(guò)程更加高效玄捕,減少DOM操作量踩蔚,提高性能。

  1. 另外枚粘,若不設(shè)置key還可能在列表更新時(shí)引發(fā)一些隱蔽的bug
  2. vue中在使用相同標(biāo)簽名元素的過(guò)渡切換時(shí)馅闽,也會(huì)使用到key屬性,其目的也是為了讓vue可以區(qū)分它們,否則vue只會(huì)替換其內(nèi)部屬性而不會(huì)觸發(fā)過(guò)渡效果福也。
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末局骤,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子暴凑,更是在濱河造成了極大的恐慌峦甩,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,198評(píng)論 6 514
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件现喳,死亡現(xiàn)場(chǎng)離奇詭異凯傲,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)嗦篱,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,334評(píng)論 3 398
  • 文/潘曉璐 我一進(jìn)店門冰单,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人灸促,你說(shuō)我怎么就攤上這事诫欠。” “怎么了腿宰?”我有些...
    開(kāi)封第一講書人閱讀 167,643評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵呕诉,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我吃度,道長(zhǎng)甩挫,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書人閱讀 59,495評(píng)論 1 296
  • 正文 為了忘掉前任椿每,我火速辦了婚禮伊者,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘间护。我一直安慰自己亦渗,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,502評(píng)論 6 397
  • 文/花漫 我一把揭開(kāi)白布汁尺。 她就那樣靜靜地躺著法精,像睡著了一般。 火紅的嫁衣襯著肌膚如雪痴突。 梳的紋絲不亂的頭發(fā)上搂蜓,一...
    開(kāi)封第一講書人閱讀 52,156評(píng)論 1 308
  • 那天,我揣著相機(jī)與錄音辽装,去河邊找鬼帮碰。 笑死,一個(gè)胖子當(dāng)著我的面吹牛拾积,可吹牛的內(nèi)容都是我干的殉挽。 我是一名探鬼主播丰涉,決...
    沈念sama閱讀 40,743評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼斯碌!你這毒婦竟也來(lái)了一死?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 39,659評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤傻唾,失蹤者是張志新(化名)和其女友劉穎摘符,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體策吠,經(jīng)...
    沈念sama閱讀 46,200評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,282評(píng)論 3 340
  • 正文 我和宋清朗相戀三年瘩绒,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了猴抹。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,424評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡锁荔,死狀恐怖蟀给,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情阳堕,我是刑警寧澤跋理,帶...
    沈念sama閱讀 36,107評(píng)論 5 349
  • 正文 年R本政府宣布,位于F島的核電站恬总,受9級(jí)特大地震影響前普,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜壹堰,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,789評(píng)論 3 333
  • 文/蒙蒙 一拭卿、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧贱纠,春花似錦峻厚、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 32,264評(píng)論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至辖试,卻和暖如春辜王,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背剃执。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,390評(píng)論 1 271
  • 我被黑心中介騙來(lái)泰國(guó)打工誓禁, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人肾档。 一個(gè)月前我還...
    沈念sama閱讀 48,798評(píng)論 3 376
  • 正文 我出身青樓摹恰,卻偏偏與公主長(zhǎng)得像辫继,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子俗慈,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,435評(píng)論 2 359