日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

詳解vue中v-for的key唯一性

瀏覽:16日期:2022-09-29 15:15:04
目錄1. DOM Diff2. 為同一層的相同類型的元素添加 key 屬性3. key 不能是 index 下標(biāo)值1. DOM Diff

要想真正了解 key 屬性的存在意義,還真得從 DOM Diff 說起,并不需要深入了解 DOM Diff 的原理,而是僅僅需要知道 DOM Diff 的工作過程即可。

Vue 和 React 都采用了運(yùn)用虛擬 DOM 的方式減少瀏覽器不必要的渲染。由于 Vue 和 React 采用的都是 v = render( m ) 的方式渲染視圖的,當(dāng) model 數(shù)據(jù)發(fā)生變化時(shí),視圖更新的方式就是重新 render DOM 元素。但是有時(shí)候我們只是改變了一個(gè)組件中的某一個(gè) div 中的數(shù)據(jù),如果采用原生 render 的方式去更新視圖的話,那整個(gè)組件都要更新。豈不浪費(fèi)時(shí)間?

我們?nèi)粘I钪信龅竭@樣的情況可不會(huì)全部更新,就像一個(gè)拼圖拼好了,后來其中一小塊需要更換,我們找到拿一塊直接替換就好了,絕不會(huì)說再從頭拼一次。Vue 和 React 的開發(fā)者也是這樣想的,就去想方設(shè)法優(yōu)化。

我們?nèi)搜垡谎劬涂梢钥闯龈淖兦昂透淖兒蟮牟煌帲桓虏煌幘涂梢粤恕5?jì)算機(jī)可一眼看不出來,它必須從頭一塊快地對(duì)比,直至找到不同之處進(jìn)行更新。這個(gè)將改變前和改變后進(jìn)行對(duì)比找不同的過程就是 DOM Diff,DOM Diff 中的 DOM 是虛擬 DOM,也就是 JavaScript 對(duì)象,一一比較找到不同之處后,就去局部更新真正的 DOM。

在比較的過程中, 虛擬 DOM 也會(huì)構(gòu)成一棵虛擬 DOM 樹,DOM Diff 的工作過程就是比較兩棵虛擬 DOM 樹上的對(duì)象節(jié)點(diǎn),具體就是每一層和每一層的對(duì)應(yīng)位置進(jìn)行比較。正是因?yàn)橛?jì)算機(jī)只會(huì)比較每一層對(duì)應(yīng)位置的的兩個(gè)虛擬 DOM 元素,如果這兩棵樹中改變后的樹的某一層只是插入了一個(gè)節(jié)點(diǎn),那樹的結(jié)構(gòu)是不變的,DOM Diff 在比較這一層的時(shí)候就會(huì)導(dǎo)致錯(cuò)位比較了,如下圖所示:

詳解vue中v-for的key唯一性

因?yàn)檫@一層的虛擬 DOM 節(jié)點(diǎn)對(duì)于 Vue 和 React 來說除了 DOM 節(jié)點(diǎn)本身外是完全沒有任何不同的,所以 DOM Diff 在比較的時(shí)候就只能按照對(duì)應(yīng)位置一一比較了。

一一比較后,如果節(jié)點(diǎn)類型相同,那么就會(huì)復(fù)用該節(jié)點(diǎn),單單局部更新該節(jié)點(diǎn)內(nèi)不同的內(nèi)容處。就像上述圖中的,如果這是 ul 下的 li 的虛擬 DOM 節(jié)點(diǎn)的話,那一一比較后發(fā)現(xiàn)節(jié)點(diǎn)類型相同,就復(fù)用之前的節(jié)點(diǎn),將節(jié)點(diǎn)里面的內(nèi)容進(jìn)行改變,也就是,將C更新成F,D更新成C,E更新成D,最后再插入E。

上述是插入節(jié)點(diǎn)的情況,帶來的后果就是效率上的降低,但如果是刪除節(jié)點(diǎn)的情況,那帶來的后果可就不僅僅是效率了。

假如是點(diǎn)擊一個(gè)按鈕刪除一個(gè) li 元素,那新舊虛擬 DOM 樹進(jìn)行比較的時(shí)候,還是根據(jù)樹中每一層的對(duì)應(yīng)位置一一比較,比如刪除后的 [1,2,3] 變成了 [1,3],它就會(huì)將第一個(gè) li 和第二個(gè) li 相比較,發(fā)現(xiàn)元素類型沒有變化,就會(huì)復(fù)用第一個(gè) li,再遞歸對(duì)比 li 里面的,發(fā)現(xiàn)都沒變化就繼續(xù)復(fù)用。到了第二個(gè) li 之間比較的時(shí)候,發(fā)現(xiàn)也都是 li 元素,那就會(huì)復(fù)用之前的li,單單將 2 變成了 3。

此時(shí),如果復(fù)用的 li 中有子元素的話,子元素依賴的數(shù)據(jù)沒有發(fā)生變化的話,就會(huì)繼續(xù)復(fù)用之前的子組件,這樣就會(huì)導(dǎo)致一個(gè)錯(cuò)位,如下圖:

詳解vue中v-for的key唯一性

2. 為同一層的相同類型的元素添加 key 屬性

在上述的 DOM Diff 算法中,比較的僅僅是兩棵樹同一層的對(duì)應(yīng)位置,在不同層之前的元素之間是不需要比較的,而且,當(dāng) DOM Diff 的過程中發(fā)現(xiàn),改變后的虛擬 DOM 和之前的虛擬 DOM 類型不同的時(shí)候,就會(huì)將之前的卸載,重新再添加改變后的元素節(jié)點(diǎn)。因此,上述的問題就出現(xiàn)在,兩棵樹中同一層的節(jié)點(diǎn)類型相同時(shí),在該層添加或刪除時(shí)會(huì)降低效率或者帶來 bug。

這就是我們?cè)?v-for 循環(huán)中生成同種類型的標(biāo)簽元素時(shí)的情況,如果不為該標(biāo)簽節(jié)點(diǎn)做點(diǎn)什么,就存在bug隱患,那么應(yīng)該做什么呢?

答案就是為同一層的相同節(jié)點(diǎn)類型的節(jié)點(diǎn)添加一個(gè)唯一標(biāo)識(shí)的 key 值,這樣,在 DOM Diff 進(jìn)行配對(duì)比較時(shí),就會(huì)將 key 相同的兩個(gè)虛擬 DOM 進(jìn)行比較,而不是僅僅按照對(duì)應(yīng)位置進(jìn)行比較了。

這樣一來就不會(huì)導(dǎo)致錯(cuò)位比較了,就大大提高了比較的效率,解決了 bug 隱患。

3. key 不能是 index 下標(biāo)值

因?yàn)閿?shù)組或?qū)ο蟮?index 下標(biāo)值是唯一的,因此我們經(jīng)常使用 index 作為 key 屬性的值,有的人說這樣是可以的,會(huì)帶來性能上的優(yōu)化什么的,但使用 index 下標(biāo)值是會(huì)有大大的 bug 隱患的。

這些 bug 會(huì)在你 v-for 循環(huán)的數(shù)組或?qū)ο蟀l(fā)生添加或刪除或順序改變時(shí)。

那么為什么不能使用 index 下標(biāo)呢?

其實(shí)就是因?yàn)?index 下標(biāo)使用了跟沒使用了一樣,因?yàn)樵谔砑雍蛣h除時(shí),某一個(gè)特定元素的 index 是會(huì)變的,比如 [1,2,3] 變成了 [1,3] 后,原來數(shù)據(jù) 3 對(duì)應(yīng)的下標(biāo)為2,刪除后數(shù)據(jù) 3 的下標(biāo)變成了 1,這在 DOM Diff 的時(shí)候,會(huì)根據(jù) key 值相等的進(jìn)行兩兩配對(duì)比較,這數(shù)據(jù)3對(duì)應(yīng)的節(jié)點(diǎn)前后還是對(duì)應(yīng)不上,因此,使用了 index 作為 key 跟沒設(shè)置 key 是一樣的效果。

這就是為什么不要使用 index 作為 key 的原因。

因此:key 屬性值必須是獨(dú)一無二的且不會(huì)改變的

以上就是詳解vue中v-for的key唯一性的詳細(xì)內(nèi)容,更多關(guān)于vue中v-for的key唯一性的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Vue
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
免费在线小视频| 成人国产精品| 99久久亚洲精品| av高清不卡| 亚洲h色精品| 91精品二区| 亚洲一区区二区| 中文无码日韩欧| 日日摸夜夜添夜夜添国产精品| 综合激情在线| 色狠狠一区二区三区| 日本午夜精品视频在线观看| 国产欧美精品| 欧美激情亚洲| 成人国产精选| 久久久亚洲一区| 在线综合视频| 日韩精品a在线观看91| 国产日韩视频| 精品一区二区三区亚洲 | 亚洲精品日本| 久久国内精品视频| 久久中文字幕导航| 久久久一二三| 视频一区视频二区中文字幕| 日韩精品国产精品| 欧美91在线| 久久久男人天堂| 欧美日韩激情| 亚洲精品无吗| 国产精品一区二区三区四区在线观看 | 国产精品亚洲综合色区韩国| 成人亚洲一区二区| 五月精品视频| 国产一区二区三区久久| 在线成人动漫av| 亚洲精品免费观看| 精品五月天堂| 欧美日韩国产在线观看网站| 日韩和欧美一区二区| 高清av一区| 免费在线视频一区| 久久精品三级| 亚洲精品网址| 国产精品一区二区av日韩在线| 伊人久久在线| 亚洲精品成人一区| 成人在线视频区| 日韩精品一级中文字幕精品视频免费观看 | 日韩和的一区二在线| 亚洲综合五月| 国产欧美高清| 午夜国产欧美理论在线播放| 国产乱码精品一区二区三区四区| 日韩一区电影| 快播电影网址老女人久久| 一区二区三区国产在线| 精品视频高潮| 免费高清在线一区| 国产成人精品一区二区三区在线| 亚洲一区二区三区高清| 国产精品nxnn| 久久aⅴ国产紧身牛仔裤| 精品国产99| 亚洲精品在线国产| 久久国产日韩| 欧美三区不卡| 香蕉精品视频在线观看| 欧美日韩xxxx| 欧美天堂亚洲电影院在线观看| 国产精品**亚洲精品| 丝袜美腿成人在线| 免费在线小视频| 国产极品久久久久久久久波多结野| 影院欧美亚洲| 成人美女视频| 国产免费久久| 首页国产欧美久久| 精品国产成人| 青草国产精品| 在线综合视频| 伊人网在线播放| 国产伦精品一区二区三区千人斩 | 亚洲婷婷丁香| 国模 一区 二区 三区| 精品亚洲成人| 国产精品亚洲一区二区在线观看| 久久性天堂网| 91成人精品| 在线视频观看日韩| sm久久捆绑调教精品一区| 国产精品欧美在线观看| 日本中文字幕一区二区| 亚洲一区二区三区免费在线观看 | 国产精品久久久久久久久久久久久久久| 国产一区成人| 在线日韩一区| 免费在线小视频| 四虎成人av| 国产精品久久久久毛片大屁完整版| 综合国产精品| 三级亚洲高清视频| 亚洲青青久久| 一区在线免费| 欧美一级精品| 欧美日韩一二三四| 水蜜桃精品av一区二区| 欧美激情麻豆| 亚洲ab电影| 日韩欧美三区| 亚洲精品综合| 综合激情一区| 蜜桃av一区二区| 天堂成人国产精品一区| 国内精品福利| 播放一区二区| 精品国模一区二区三区| 日韩久久一区二区三区| 久久久久美女| 999久久久91| 国产精品亚洲一区二区三区在线观看| 国产日韩1区| 久久国产精品色av免费看| 日韩在线观看一区二区三区| 最新亚洲国产| 日韩精品视频中文字幕| 日韩av黄色在线| 国产探花一区在线观看| 欧美一区精品| 日韩av成人高清| 91亚洲无吗| 国产乱人伦丫前精品视频| 久久不见久久见免费视频7 | 老牛影视一区二区三区| 亚洲欧洲国产精品一区| 日韩一区免费| 国产欧美日韩精品高清二区综合区| 国产乱码精品一区二区三区亚洲人 | 日韩精品免费一区二区夜夜嗨| 亚洲理论在线| 欧美日韩18| 久久字幕精品一区| 久久影院资源站| 日韩美女一区二区三区在线观看| 久久免费黄色| 一区免费在线| 水野朝阳av一区二区三区| 日韩欧美中文字幕电影| 国产精品亚洲综合久久| 国产精品二区不卡| 免费视频一区三区| 伊人久久大香伊蕉在人线观看热v| 色综合视频一区二区三区日韩 | 日韩欧美少妇| 夜久久久久久| 日本不卡一二三区黄网| 国产精品一区二区三区av| 成人污污视频| 亚洲精品99| 日韩av资源网| 国产成人黄色| 午夜欧美精品久久久久久久| 少妇精品久久久| 精品视频在线观看网站| 成人亚洲欧美| 国产亚洲在线| 国产图片一区| 99视频精品全国免费| 亚洲毛片视频| 另类专区亚洲| 在线精品观看| 美女视频黄免费的久久| 99tv成人| 日本精品一区二区三区在线观看视频| 98精品视频| 爽爽淫人综合网网站| 久久久91麻豆精品国产一区| 米奇777超碰欧美日韩亚洲| 青青草国产精品亚洲专区无| 日韩精品中文字幕第1页| 亚洲精品高潮| 日韩国产欧美| 亚洲精品综合| 成人片免费看| 日本成人在线一区| 亚洲风情在线资源| 日韩在线卡一卡二| 国产精品原创| 综合欧美精品| 播放一区二区| 国产精品jk白丝蜜臀av小说| 国产专区一区| 国产精品久久久久久久久久白浆 | 欧美成人高清| 国产精品流白浆在线观看| 亚洲在线网站| 成人av三级| 婷婷综合一区| 国产专区一区| 91亚洲自偷观看高清|