亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue中為什么不推薦用index做key詳解

 更新時間:2022年09月07日 10:21:06   作者:高志鵬  
Vue中使用虛擬dom且根據(jù)diff算法進行新舊DOM對比,從而更新真實 dom,key是虛擬DOM對象的唯一標識,在diff算法中key起著極其重要的作用,下面這篇文章主要給大家介紹了關(guān)于Vue中為什么不推薦用index做key的相關(guān)資料,需要的朋友可以參考下

前言

尤大在vue 2.x的文檔中明確指出:建議盡可能在使用 v-for 時提供 key attribute,除非遍歷輸出的 DOM 內(nèi)容非常簡單,或者是刻意依賴默認行為以獲取性能上的提升。

尤大的建議說白了就是說:

如果index可以做key,那直接底層幫你傳進去好了,又何必讓你們多此一舉呢?乖乖的不要用index做key

那么:key 到底有什么用? 當 Vue.js 用 v-for 正在更新已渲染過的元素列表時,它默認用就地復用策略 。 這句話是什么意思?

讓我們一起去探討吧

diff算法

簡單的說就是新舊虛擬dom的比較,如果有差異就以新的為準,然后再插入的真實的dom中,重新渲染

key的作用

一句話: key的作用主要是為了更高效的對比虛擬DOM中每個節(jié)點是否是相同節(jié)點;

舉個簡單的例子

三胞胎戰(zhàn)成一排,你怎么知道誰是老大?

如果老大皮了一下子,和老三換了一下位置,你又如何區(qū)分出來?

給他們掛個牌牌,寫上老大、老二、老三。

這樣就不會認錯了。key就是這個作用。

通過 key 管理狀態(tài)

Vue 默認按照“就地更新”的策略來更新通過 v-for 渲染的元素列表。當數(shù)據(jù)項的順序改變時,Vue 不會隨之移動 DOM 元素的順序,而是就地更新每個元素,確保它們在原本指定的索引位置上渲染。

默認模式是高效的,但只適用于列表渲染輸出的結(jié)果不依賴子組件狀態(tài)或者臨時 DOM 狀態(tài) (例如表單輸入值) 的情況。

為了給 Vue 一個提示,以便它可以跟蹤每個節(jié)點的標識,從而重用和重新排序現(xiàn)有的元素,你需要為每個元素對應(yīng)的塊提供一個唯一的 key attribute:

在沒有 key 的情況下,Vue 將使用一種最小化元素移動的算法,并盡可能地就地更新/復用相同類型的元素。如果傳了 key,則將根據(jù) key 的變化順序來重新排列元素,并且將始終移除/銷毀 key 已經(jīng)不存在的元素。

同一個父元素下的子元素必須具有唯一的 key。重復的 key 將會導致渲染異常

效率 & Bug

說到這,有些人就是認為是簡單的效率問題。

確實:設(shè)置key可以讓diff更高效,但僅僅是重繪重排嗎?

答案是否定的

如果僅僅是效率低下,在操作極少的元素中,也無傷大雅。

但是,使用index帶來的問題卻要麻煩的多

<div id="app">
    <Child v-for="item,i in array" :text="item" @delete="remove(i)"/>
</div>

data() {
    return {
      array: [1, 2, 3]
    };
},
methods: {
    remove(i) {
      this.array.splice(i, 1);
    }
}
此時,key的作用就是為了復用。正是因為會復用,所以用index來做key會出現(xiàn)復用錯誤的問題, 造成意想不到的bug

總結(jié)

最簡單方便的就是:使用數(shù)據(jù)庫中的 id

如果返回值中沒有id怎么辦

  • 創(chuàng)建一個自增id函數(shù),每次調(diào)用自增一
  • 使用uuid庫

到此這篇關(guān)于Vue中為什么不推薦用index做key的文章就介紹到這了,更多相關(guān)Vue不推薦用index做key內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 解決vue同一slot在組件中渲染多次的問題

    解決vue同一slot在組件中渲染多次的問題

    今天小編就為大家分享一篇解決vue同一slot在組件中渲染多次的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • vue實現(xiàn)樹狀表格效果

    vue實現(xiàn)樹狀表格效果

    這篇文章主要為大家詳細介紹了vue實現(xiàn)樹狀表格效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-12-12
  • Vue?使用postMessage?實現(xiàn)父子跨域通信

    Vue?使用postMessage?實現(xiàn)父子跨域通信

    這篇文章主要介紹了Vue應(yīng)用?postMessage?實現(xiàn)父子跨域通信,通過示例介紹了postMessage的使用,本文結(jié)合示例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2022-12-12
  • 詳解vue中在父組件點擊按鈕觸發(fā)子組件的事件

    詳解vue中在父組件點擊按鈕觸發(fā)子組件的事件

    這篇文章主要介紹了詳解vue中在父組件點擊按鈕觸發(fā)子組件的事件,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-11-11
  • Vue Element-UI中el-table實現(xiàn)單選的示例代碼

    Vue Element-UI中el-table實現(xiàn)單選的示例代碼

    在element-ui中是為我們準備好了可直接使用的單選與多選屬性的,本文主要介紹了Vue Element-UI中el-table實現(xiàn)單選的示例代碼,具有一定的參考價值,感興趣的可以了解一下
    2023-12-12
  • 詳解在vue-cli3.0中自定css、js和圖片的打包路徑

    詳解在vue-cli3.0中自定css、js和圖片的打包路徑

    這篇文章主要介紹了詳解在vue-cli3.0中自定css、js和圖片的打包路徑,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-08-08
  • Vue中使用provide和inject實例對比分析

    Vue中使用provide和inject實例對比分析

    這篇文章主要為大家介紹了Vue中使用provide和inject實例對比分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-08-08
  • vue表格(table)計算總計方式

    vue表格(table)計算總計方式

    這篇文章主要介紹了vue表格(table)計算總計方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • Vue 實現(xiàn)輸入框新增搜索歷史記錄功能

    Vue 實現(xiàn)輸入框新增搜索歷史記錄功能

    這篇文章主要介紹了Vue 輸入框新增搜索歷史記錄功能,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-10-10
  • vue+vant實現(xiàn)商品列表批量倒計時功能

    vue+vant實現(xiàn)商品列表批量倒計時功能

    這篇文章主要介紹了vue+vant實現(xiàn)商品列表批量倒計時功能,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-01-01

最新評論