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

Vue中key的作用及原理詳解

 更新時間:2021年10月12日 16:20:55   作者:沒事就寫點程序  
本文主要介紹了Vue3中key的作用和工作原理,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

1. 先說結(jié)論

  • key在Vue是DOM對象的標(biāo)識;
  • 進行列表展示時,默認key是index;
  • 如果數(shù)據(jù)只做展示使用,使用index作為key是沒有任何問題的;
  • 如果使用index作為key,而后續(xù)操作會破壞順序,一定會帶來效率問題,嚴重時會渲染出錯誤的DOM

關(guān)于key的作用及實現(xiàn)原理,下面一一道來。

2. key的作用

key就是一個標(biāo)識,被使用在Vue中。再詳細一點,key被使用在Vue中的虛擬DOM中,并不會出現(xiàn)在真實DOM中。

2.1 舉一個例子

以列表的形式展示一組人員信息。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>key的原理</title>

    <!--引入vue-->
    <script type="text/javascript" src="../js/vue.js"></script>
    
</head>
<div id="root">
    <h2>人員列表</h2>
    <ul>
        <li v-for="(p,index) in persons">
            {{p.name}}-{{p.age}}
        </li>
    </ul>
</div>
<body>
    <script type="text/javascript">
        const vm = new Vue({
            el:'#root',
            data:{
                persons:[
                    {'id':'001', 'name':'張三','age':'18'},
                    {'id':'002', 'name':'李四','age':'19'},
                    {'id':'003', 'name':'王五','age':'20'}
                ]
            }
        })
    </script>
</body>
</html>

這個html文件在瀏覽器中打開如下圖所示。

image-20211011224230413

而上述示例html文件中并沒有使用到key,似乎也沒有問題。當(dāng)然,單純地展示數(shù)據(jù),不寫key是不會存在問題的。

現(xiàn)在我們?yōu)樯鲜鍪纠由蟢ey,這里以每條數(shù)據(jù)的id為key

<li v-for="(p,index) in persons" :key="p.id">
    {{p.name}}-{{p.age}}
</li>

加上key的展示結(jié)果和上圖結(jié)果一模一樣。

image-20211011224928540

而如果我們在瀏覽器上查看元素,不會看到key的存在。

image-20211011225246624

截至目前,我們可以得到兩個結(jié)論:1. 只做數(shù)據(jù)展示用,不寫key是沒有任何影響的;2.key不會出現(xiàn)在真實DOM中

實際上,即使不寫key,Vue在生成真實DOM時,也用到了key,默認是數(shù)據(jù)索引(index)

我們把key替換為index,展示的數(shù)據(jù)不會產(chǎn)生任何改變。

<li v-for="(p,index) in persons" :key="index">
	{{p.name}}-{{p.age}}
</li>

2.2 修改一下上述示例

在展示人員信息的基礎(chǔ)上顯示索引,并且添加一個按鈕,功能是在頭部添加人員信息

對上述html文件稍加修改。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>key的原理</title>

    <!--引入vue-->
    <script type="text/javascript" src="../js/vue.js"></script>
    <link rel="icon" href="../favicon.ico" type="image/x-icon" />

</head>
<div id="root">
    <h2>人員列表</h2>
    <button @click="add">添加一個老劉</button>
    <ul>
        <li v-for="(p,index) in persons" :key="index">
            {{p.name}}-{{p.age}}-{{index}}
        </li>
    </ul>
</div>
<body>
    <script type="text/javascript">
        const vm = new Vue({
            el:'#root',
            data:{
                persons:[
                    {'id':'001', 'name':'張三','age':'18'},
                    {'id':'002', 'name':'李四','age':'19'},
                    {'id':'003', 'name':'王五','age':'20'}
                ]
            },
            methods:{
                add(){
                    const p = {'id':'004', 'name':'老劉','age':'40'}
                    this.persons.unshift(p)
                }
            }
        })
    </script>
</body>
</html>

我們可以看到,張三、李四、王五的索引分為別0,1,2

image-20211011230442273

點擊按鈕,添加一個新人物,這個時候索引發(fā)生了變化,新添加的人物“老劉”變?yōu)榱怂饕?,似乎對,也似乎不對

image-20211011230815984

當(dāng)然,單純地討論索引,這里一點問題也沒有,下面舉一個新例子,來說說“不對“在哪里

2.3 再修改一下示例

不展示索引了,改為輸入框,在每個人物后面的輸入框內(nèi)寫上人物的姓,觀察新插入數(shù)據(jù)后原始數(shù)據(jù)的變化

稍微修改一下html

<li v-for="(p,index) in persons" :key="index">
    {{p.name}}-{{p.age}}
    <input type="text">
</li>

實際效果就是下圖這樣

image-20211011231349758

到這里,似乎沒有什么不對,接下來就是見證奇跡的時刻

添加老劉,出現(xiàn)了問題,和我們預(yù)想的不一樣。

image-20211011231548484

這是key為index的情況,如果修改為數(shù)據(jù)的唯一標(biāo)識,則不會產(chǎn)生這樣的問題。

<li v-for="(p,index) in persons" :key="p.id">
    {{p.name}}-{{p.age}}
    <input type="text">
</li>

誒,這就是我們想要的。

image-20211011231848647

列表內(nèi)有輸入內(nèi)容,后續(xù)操作會破壞原始順序,就會產(chǎn)生錯誤DOM

3. key的實現(xiàn)原理

要解釋key的實現(xiàn)原理,就要引入Vue一個十分重要的概念——【虛擬DOM】。

給出一組數(shù)據(jù),Vue要把這些數(shù)據(jù)渲染到頁面上,首先要生成【虛擬DOM】,然后根據(jù)【虛擬DOM】去生成【真實的DOM】。如果數(shù)據(jù)發(fā)生了改變,Vue會生成【新的虛擬DOM】,注意,這個【新的虛擬DOM】并不會直接生成【新的真實DOM】,否則虛擬DOM一點用處也沒有了。Vue的操作是,拿根據(jù)新的數(shù)據(jù)生成的【新的虛擬DOM】與之前的【真實的DOM】去做比較,如果相同,直接延用即可(“拿來主義”);如果不同,則生成新的DOM對象。

在這個過程中key扮演了很重要的角色。

根據(jù)最后一個示例進行剖析。

1. key為index的情況。

根據(jù)數(shù)據(jù)生成【真實DOM】的流程如下:(注意,下圖的真實DOM中輸入框里的內(nèi)容為生成頁面后手動添加)

在這里插入圖片描述

然后,添加人物“老劉”,獲取到一組新數(shù)據(jù)

在這里插入圖片描述

Vue拿新數(shù)據(jù)生成【新的虛擬DOM】

在這里插入圖片描述

在生成真實DOM,就需要用新生成的虛擬DOM和原來的真實DOM作比較(一條一條分析)

在這里插入圖片描述

對比第一條,key為0,找到舊DOM中key為0的數(shù)據(jù),發(fā)現(xiàn)“老劉-40”和“張三-18”不同,渲染新的數(shù)據(jù)“老劉-40”到頁面上;再往后,發(fā)現(xiàn)同為輸入框,不必重新渲染,直接使用原來真實DOM的內(nèi)容。第一條內(nèi)容就出現(xiàn)了,而這個輸入框還攜帶有張三的姓。

在這里插入圖片描述

對比第二條,key為1,找到舊DOM中key為1的數(shù)據(jù),發(fā)現(xiàn)“張三-18”和“李四-19”不同,渲染新的數(shù)據(jù)“張三-18”到頁面上;再往后,發(fā)現(xiàn)同為輸入框,不必重新渲染,直接使用原來真實DOM的內(nèi)容。第二條內(nèi)容就出現(xiàn)了,而這個輸入框還攜帶有李四的姓。

在這里插入圖片描述

之后同理。

回顧這個過程,key是作為虛擬DOM中對象的唯一標(biāo)識,標(biāo)識出了數(shù)據(jù)的“身份信息”,Vue在虛擬DOM中會根據(jù)這個“身份標(biāo)識”去對比內(nèi)容,設(shè)計的初衷是為了節(jié)省資源開支,不必渲染重復(fù)的部分。在本示例中,不但帶來了效率問題,還渲染出了錯誤的DOM,后果非常嚴重。

2. key為id的情況。

直接進入添加“老劉”后的新舊DOM對比。

在這里插入圖片描述

對比第一條,key為‘004',發(fā)現(xiàn)在舊DOM中并不存在,直接生成“老劉-40”和新的輸入框。

對比第二條,key為‘001',發(fā)現(xiàn)舊DOM中key為‘001'的數(shù)據(jù)相同,直接將“張三-18”和輸入框拿過來使用。

……

最后生成正確的DOM,節(jié)省了資源開支。

總結(jié)

推薦使用數(shù)據(jù)的唯一標(biāo)識作為key,比如id,身份證號,手機號等等,通常這些數(shù)據(jù)由后端提供。

后續(xù)操作不破壞原來數(shù)據(jù)順序的話,使用index作為key也沒有任何問題。

本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!

相關(guān)文章

  • Vue Element前端應(yīng)用開發(fā)之整合ABP框架的前端登錄

    Vue Element前端應(yīng)用開發(fā)之整合ABP框架的前端登錄

    VUE+Element 前端是一個純粹的前端處理,前面介紹了很多都是Vue+Element開發(fā)的基礎(chǔ),從本章隨筆開始,就需要進入深水區(qū)了,需要結(jié)合ABP框架使用
    2021-05-05
  • Vue3中的ref為何要用.value進行值的調(diào)用呢

    Vue3中的ref為何要用.value進行值的調(diào)用呢

    這篇文章主要介紹了Vue3中的ref為何要用.value進行值的調(diào)用,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • vue中如何下載文件導(dǎo)出保存到本地

    vue中如何下載文件導(dǎo)出保存到本地

    這篇文章主要介紹了vue中如何下載文件導(dǎo)出保存到本地,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • vue3.0中使用postcss-pxtorem的具體方法

    vue3.0中使用postcss-pxtorem的具體方法

    這篇文章主要介紹了vue3.0中使用postcss-pxtorem的具體方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • 在使用vuex的時候出現(xiàn)commit未定義錯誤的解決

    在使用vuex的時候出現(xiàn)commit未定義錯誤的解決

    這篇文章主要介紹了在使用vuex的時候出現(xiàn)commit未定義錯誤的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • Vue3中的執(zhí)行流程思路分析-流程圖

    Vue3中的執(zhí)行流程思路分析-流程圖

    這篇文章主要介紹了Vue3中的執(zhí)行流程思路分析,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • atom-design(Vue.js移動端組件庫)手勢組件使用教程

    atom-design(Vue.js移動端組件庫)手勢組件使用教程

    這篇文章主要介紹了atom-design(Vue.js移動端組件庫)手勢組件使用教程,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-05-05
  • vue中實現(xiàn)當(dāng)前時間echarts圖表時間軸動態(tài)的數(shù)據(jù)(實例代碼)

    vue中實現(xiàn)當(dāng)前時間echarts圖表時間軸動態(tài)的數(shù)據(jù)(實例代碼)

    這篇文章主要介紹了vue中實現(xiàn)當(dāng)前時間echarts圖表時間軸動態(tài)的數(shù)據(jù),本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-10-10
  • Vue3使用ref解決GetElementById為空的問題

    Vue3使用ref解決GetElementById為空的問題

    今天遇到一個問題,就是在Vue3組件中需要獲取template中的元素節(jié)點,使用GetElementById返回的卻是null,網(wǎng)上查找了好些資料,才發(fā)需要使用ref,所以本文給大家介紹了Vue3組件中如何使用ref解決GetElementById為空的問題,需要的朋友可以參考下
    2023-12-12
  • vue-router+nginx 非根路徑配置方法

    vue-router+nginx 非根路徑配置方法

    這篇文章主要介紹了vue-router+nginx 非根路徑配置方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-06

最新評論