欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue和react項(xiàng)目中key的作用示例詳解

 更新時(shí)間:2023年08月07日 10:59:41   作者:劉鵬瑜  
這篇文章主要為大家介紹了vue和react項(xiàng)目中key的作用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

vue react對比新舊虛擬節(jié)點(diǎn)

vue和react都是采用diff算法來對比新舊虛擬節(jié)點(diǎn),從而更新節(jié)點(diǎn)。

在交叉對比中,當(dāng)新節(jié)點(diǎn)跟舊節(jié)點(diǎn)頭尾交叉對比沒有結(jié)果時(shí),會(huì)根據(jù)新節(jié)點(diǎn)的key去對比舊節(jié)點(diǎn)數(shù)組中的key,從而找到相應(yīng)的舊節(jié)點(diǎn)(這里對應(yīng)的是一個(gè)key=>index的map映射)。

如果沒有找到就認(rèn)為是一個(gè)新增節(jié)點(diǎn)。而如果沒有key,那么就會(huì)采用遍歷查找的方式去找到對應(yīng)的舊節(jié)點(diǎn),一種一個(gè)map映射,另一種是遍歷查找。相比而言,map映射速度更快。

vue部分源碼如下

//vue項(xiàng)目 src/core/vdom/patch.js -448行
//oldCh是一個(gè)舊虛擬節(jié)點(diǎn)數(shù)組
if(isUndef(oldKeyToIdx)){
    oldKeyToIdx = createKeyToOldIdx(oldCh,oldStartIdx,oldEndIdx)
}
if(isDef(newStartVnode.key)){
    //map方式獲取
    idxInOld = oldKeyToIdx[newStartVnode.key]
}else {
    //遍歷方式獲取
    idxInOld = findIdxInOld(newStartVnode,oldCh,oldStartIdx,oldEndIdx)
}

創(chuàng)建map函數(shù)

function createKeyToOldIdx(children,beginIdx,endIdx){
    let i,key
    const map = {}
    for(i = beginIdx;i<=endIdx;i++){
        key = children[i].key
        if(isDef(key)) map[key] = i    
    }
    return map
}

遍歷尋找

//sameVnode 是對比新舊節(jié)點(diǎn)是否相同的函數(shù)
function findIdxInOld(node,oldCh,start,end){
    for(let i = start;i<end;i++){
        const c = oldCh[i]
        if(isDef(c) && sameVnode(node,c)) return i    
    }
}

上面的結(jié)論是基于沒有key的情況diff速度會(huì)更快。確實(shí),這種觀點(diǎn)沒有錯(cuò)。沒有綁定key的情況下,并且在遍歷模版簡單的情況下,會(huì)導(dǎo)致虛擬新舊節(jié)點(diǎn)對比更快,節(jié)點(diǎn)也會(huì)復(fù)用。而這種復(fù)用是就地復(fù)用,一種鴨子辯型的復(fù)用。以下為簡單的例子:

<div id="app">
    <div v-for="i in dataList">{{ i }}</div>
</div>
var vm = new Vue({
    el:'#app',
    data:{
        dataList:[1,2,3,4,5]    
    }
})

以上的例子,v-for的內(nèi)容會(huì)生成以下的dom節(jié)點(diǎn)數(shù)組,我們給每一個(gè)節(jié)點(diǎn)標(biāo)記一個(gè)身份id:

[
    '<div>1</div>',//id:A
    '<div>2</div>',//id:B
    '<div>3</div>',//id:C
    '<div>4</div>',//id:D
    '<div>5</div>',//id:E
]

改變dataList數(shù)據(jù),進(jìn)行數(shù)據(jù)位置替換,對比改變后的數(shù)據(jù)

vm.dataList = [4,1,3,5,2]//數(shù)據(jù)位置替換
//沒有key的情況,節(jié)點(diǎn)位置不變,但是節(jié)點(diǎn)innerText內(nèi)容更新了
[
    '<div>4</div>',//id:A
    '<div>1</div>',//id:B
    '<div>3</div>',//id:C
    '<div>5</div>',//id:D
    '<div>2</div>',//id:E
]
//有key的情況,dom節(jié)點(diǎn)位置進(jìn)行了交換,但是內(nèi)容沒有更新
// <div v-for="i in dataList" :key='i'>{{ i }}</div>
[
    '<div>4</div>',//id:D
    '<div>1</div>',//id:A
    '<div>3</div>',//id:C
    '<div>5</div>',//id:E
    '<div>2</div>',//id:B
]

增刪dataList列表項(xiàng)

vm.dataList = [3,4,5,6,7] //數(shù)據(jù)進(jìn)行增刪
// 1、沒有key的情況,節(jié)點(diǎn)位置不變,內(nèi)容也更新了
[
    '<div>3</div>',//id:A
    '<div>4</div>',//id:B
    '<div>5</div>',//id:C
    '<div>6</div>',//id:D
    '<div>7</div>',//id:E
]
// 2、有key的情況,節(jié)點(diǎn)刪除了A B節(jié)點(diǎn),新增了F G節(jié)點(diǎn)
// <div v-for="i in dataLIST" :key='i'>{{ i }}</div>
[
    '<div>3</div>',//id:C
    '<div>4</div>',//id:D
    '<div>5</div>',//id:E
    '<div>6</div>',//id:F
    '<div>7</div>',//id:G
]

從以上來看,不帶有key,并且使用簡單的模版,可以更有效的復(fù)用節(jié)點(diǎn),diff速度也是不帶key更加快速的,因?yàn)閹в衚ey在增刪節(jié)點(diǎn)上有耗時(shí)。這就是vue文檔所說的默認(rèn)模式。但是這個(gè)并不是key作用,而是沒有key的情況下可以對節(jié)點(diǎn)就地復(fù)用,提高性能。

這種模式會(huì)帶來一些隱藏的副作用,比如可能不會(huì)產(chǎn)生過度效果,或者在某些節(jié)點(diǎn)有綁定數(shù)據(jù)(表單)狀態(tài),會(huì)出現(xiàn)狀態(tài)錯(cuò)位。vue文檔也說明了這個(gè)模式是高效的,但是只是適用于不依賴子組件狀態(tài)或臨時(shí)dom狀態(tài)(例如:表單輸入值)的列表渲染輸出

但是key的作用是什么?

key是給每個(gè)vnode的唯一id,可以依靠key,更快的拿到oldVnode中對應(yīng)的vnode節(jié)點(diǎn)。

1、更準(zhǔn)確

因?yàn)閹ey就不是就地復(fù)用了,在sameNode函數(shù)a.key === b.key對比中可以避免就地服用的情況。所以會(huì)更加準(zhǔn)確。

2、更快

利用key的唯一性生成map對象來獲取對應(yīng)節(jié)點(diǎn),比遍歷方式更快。

以上就是vue和react項(xiàng)目中key的作用示例詳解的詳細(xì)內(nèi)容,更多關(guān)于vue react項(xiàng)目key作用的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Vue中ref、computed與reactive使用頻率現(xiàn)象分析(示例詳解)

    Vue中ref、computed與reactive使用頻率現(xiàn)象分析(示例詳解)

    這篇文章主要分析了Vue中的ref、computed和reactive三個(gè)響應(yīng)式API的使用頻率和優(yōu)勢,ref適合處理簡單數(shù)據(jù)類型的響應(yīng)式需求,感興趣的朋友跟隨小編一起看看吧
    2024-11-11
  • 前端數(shù)據(jù)存儲(chǔ)常用工具Vuex、Pinia、Redux詳解

    前端數(shù)據(jù)存儲(chǔ)常用工具Vuex、Pinia、Redux詳解

    Redux、Vuex 和 Pinia 都是用于狀態(tài)管理的流行框架,這篇文章主要介紹了前端數(shù)據(jù)存儲(chǔ)常用工具Vuex、Pinia、Redux的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2025-04-04
  • Vue.js仿Metronic高級表格(一)靜態(tài)設(shè)計(jì)

    Vue.js仿Metronic高級表格(一)靜態(tài)設(shè)計(jì)

    這篇文章主要為大家詳細(xì)介紹了Vue.js仿Metronic高級表格的靜態(tài)設(shè)計(jì),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • SpringBoot+Vue開發(fā)之Login校驗(yàn)規(guī)則、實(shí)現(xiàn)登錄和重置事件

    SpringBoot+Vue開發(fā)之Login校驗(yàn)規(guī)則、實(shí)現(xiàn)登錄和重置事件

    這篇文章主要介紹了SpringBoot+Vue開發(fā)之Login校驗(yàn)規(guī)則、實(shí)現(xiàn)登錄和重置事件,本文通過圖文實(shí)例相結(jié)合給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-10-10
  • vue中兩種路由模式的實(shí)現(xiàn)詳解

    vue中兩種路由模式的實(shí)現(xiàn)詳解

    這篇文章主要為大家詳細(xì)介紹了vue中兩種路由模式的實(shí)現(xiàn),文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價(jià)值,感興趣的小伙伴可以了解一下
    2023-08-08
  • Vue項(xiàng)目實(shí)現(xiàn)簡單的權(quán)限控制管理功能

    Vue項(xiàng)目實(shí)現(xiàn)簡單的權(quán)限控制管理功能

    這篇文章主要介紹了Vue項(xiàng)目實(shí)現(xiàn)簡單的權(quán)限控制功能,文中給大家介紹了兩種方式進(jìn)行權(quán)限限制,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2019-07-07
  • Vue.js如何實(shí)現(xiàn)路由懶加載淺析

    Vue.js如何實(shí)現(xiàn)路由懶加載淺析

    Vue是可以自定義指令的,最近學(xué)習(xí)過程中遇見了一個(gè)需要懶加載的功能,發(fā)現(xiàn)網(wǎng)上這方面的資料較少,所以下面這篇文章主要給大家介紹了關(guān)于Vue.js如何實(shí)現(xiàn)路由懶加載的相關(guān)資料,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-08-08
  • Vue3 ref構(gòu)建響應(yīng)式變量失效問題及解決

    Vue3 ref構(gòu)建響應(yīng)式變量失效問題及解決

    這篇文章主要介紹了Vue3 ref構(gòu)建響應(yīng)式變量失效問題及解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • element UI 中的 el-tree 實(shí)現(xiàn) checkbox 單選框及 bus 傳遞參數(shù)功能

    element UI 中的 el-tree 實(shí)現(xiàn) checkbox&n

    在日常項(xiàng)目開發(fā)中,會(huì)經(jīng)常遇到,樹形結(jié)構(gòu)的查詢方式,為了快速方便開發(fā),常常會(huì)使用到快捷的ui組件去快速搭樹形結(jié)構(gòu),這里我用的是 element ui 中的 el-tree,對element UI 中的 el-tree 實(shí)現(xiàn) checkbox 單選框及 bus 傳遞參數(shù)的方法感興趣的朋友跟隨小編一起看看吧
    2022-09-09
  • vue中循環(huán)請求接口參數(shù)問題及解決

    vue中循環(huán)請求接口參數(shù)問題及解決

    這篇文章主要介紹了vue中循環(huán)請求接口參數(shù)問題及解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08

最新評論