使用v-for時:key的作用

如果覺得還有點(diǎn)用整袁,請您給我一個贊矫废!您的贊是我堅(jiān)持下去的動力

我們使用一個案例來分析,上代碼疹启,我利用transition來讓大家直觀的看到dom有沒有被刪除或增加

/**這里沒有綁定key**/
<div @click="btnLabel" v-for="(item,idx) in listNoKey">
  <transition name="fade2" mode="out-in">
    <div @click="btnLabel">
      <p>{{item.name}}</p>
    </div>
  </transition>
</div>
/**這里綁定了key**/
<div v-for="(item,idx) in listWithKey">
  <transition name="fade2" mode="out-in">
    <div @click="btnLabel" :key="item.name">
      <p>{{item.name}}</p>
    </div>
  </transition>
</div>

然后當(dāng)點(diǎn)擊按鈕的時候林说,我們改變第一個item的屬性值粘驰,使它發(fā)生改變,我們看看dom渲染的結(jié)果怎么樣

  • 第一段代碼述么,由于沒有給綁定key,vue會盡可能保留原來的dom愕掏,只修改它同原來的dom不一樣的屬性而已度秘,所以只是p標(biāo)簽內(nèi)的innerText發(fā)生了改變

  • 第二段代碼,由于給v-for的子對象綁定了唯一key并且這個key值是同item.name同步的饵撑,所以當(dāng)改變item.name屬性的時候剑梳,vue認(rèn)為老的dom被移除了,新的dom被創(chuàng)建了(因?yàn)橹皇怯胟ey來識別dom是不是原來的)滑潘,所以看到了transition發(fā)生了效果

總結(jié)

  • key的原理
    key的原理就是將原來對比DOM細(xì)節(jié)來檢測變動改為了通過key的比較來檢測垢乙,更快更準(zhǔn)確了

  • 什么時候需要用到key?
    1、當(dāng)key綁定的屬性發(fā)生變化時语卤,希望立馬可以發(fā)生transition動畫效果的情況(常用)
    2追逮、當(dāng)key綁定的屬性發(fā)生變化時,希望重新渲染該dom節(jié)點(diǎn)的時候

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末粹舵,一起剝皮案震驚了整個濱河市钮孵,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌眼滤,老刑警劉巖巴席,帶你破解...
    沈念sama閱讀 217,406評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異诅需,居然都是意外死亡漾唉,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評論 3 393
  • 文/潘曉璐 我一進(jìn)店門堰塌,熙熙樓的掌柜王于貴愁眉苦臉地迎上來赵刑,“玉大人,你說我怎么就攤上這事蔫仙×暇Γ” “怎么了?”我有些...
    開封第一講書人閱讀 163,711評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長恤煞。 經(jīng)常有香客問我屎勘,道長,這世上最難降的妖魔是什么居扒? 我笑而不...
    開封第一講書人閱讀 58,380評論 1 293
  • 正文 為了忘掉前任概漱,我火速辦了婚禮,結(jié)果婚禮上喜喂,老公的妹妹穿的比我還像新娘瓤摧。我一直安慰自己,他們只是感情好玉吁,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,432評論 6 392
  • 文/花漫 我一把揭開白布照弥。 她就那樣靜靜地躺著,像睡著了一般进副。 火紅的嫁衣襯著肌膚如雪这揣。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,301評論 1 301
  • 那天影斑,我揣著相機(jī)與錄音给赞,去河邊找鬼。 笑死矫户,一個胖子當(dāng)著我的面吹牛片迅,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播皆辽,決...
    沈念sama閱讀 40,145評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼柑蛇,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了膳汪?” 一聲冷哼從身側(cè)響起唯蝶,我...
    開封第一講書人閱讀 39,008評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎遗嗽,沒想到半個月后粘我,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,443評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡痹换,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,649評論 3 334
  • 正文 我和宋清朗相戀三年征字,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片娇豫。...
    茶點(diǎn)故事閱讀 39,795評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡匙姜,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出冯痢,到底是詐尸還是另有隱情氮昧,我是刑警寧澤框杜,帶...
    沈念sama閱讀 35,501評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站袖肥,受9級特大地震影響咪辱,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜椎组,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,119評論 3 328
  • 文/蒙蒙 一油狂、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧寸癌,春花似錦专筷、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,731評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至溪烤,卻和暖如春弦聂,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背氛什。 一陣腳步聲響...
    開封第一講書人閱讀 32,865評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留匪凉,地道東北人枪眉。 一個月前我還...
    沈念sama閱讀 47,899評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像再层,于是被迫代替她去往敵國和親贸铜。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,724評論 2 354

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

  • vue概述sd 在官方文檔中棍鳖,有一句話對Vue的定位說的很明確:Vue.js 的核心是一個允許采用簡潔的模板語法來...
    去年的牛肉閱讀 4,046評論 0 1
  • Vue 實(shí)例 屬性和方法 每個 Vue 實(shí)例都會代理其 data 對象里所有的屬性:var data = { a:...
    云之外閱讀 2,207評論 0 6
  • 主要還是自己看的,所有內(nèi)容來自官方文檔碗旅。 介紹 Vue.js 是什么 Vue (讀音 /vju?/渡处,類似于 vie...
    Leonzai閱讀 3,348評論 0 25
  • Vue是一個前端js框架,由尤雨溪開發(fā)祟辟,是個人項(xiàng)目 Vue近幾年來特別的受關(guān)注医瘫,三年前的時候angularJS霸占...
    6e5e50574d74閱讀 551評論 0 0
  • Swift1> Swift和OC的區(qū)別1.1> Swift沒有地址/指針的概念1.2> 泛型1.3> 類型嚴(yán)謹(jǐn) 對...
    cosWriter閱讀 11,100評論 1 32