1. 程式人生 > 程式設計 >VUE v-for中的:key詳解

VUE v-for中的:key詳解

不在v-for的標籤中加入key時。

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width,initial-scale=1.0">
  <script src="../..//.js"></script>
  <title>關於v-for的key</title>
</head>
<body>
  <div id="app">
    <div>
      <input type="text" v-model="name">
      <button @click="add">新增</button>
    </div>
    <ul>
      <li v-for="(item,index) in list">
        <input type="checkbox"> {{item.name}}
      </li>
    </ul>
  </div>
  <scrhttp://www.cppcns.com
ipt type="text/"> const app = new Vue({ el: '#app',data() { return { name: '',newId: 3,list: [ { id: 1,name: '張三' },{ id: 2,name: '李四' },{ id: 3,name: '王五' } ],}; }, computed: { },methods: { add() { //注意這裡是unshift this.list.unshift({ id: ++this.newId,name: this.name }) this.name = '' } },}); </script> <style scoped> </style> </body> </html>

在我們選中李四並新增趙六後,被選中的人變成了張三。

在這裡插入圖片描述

在這裡插入圖片描述

再來看v-for有key的情況:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width,initial-scale=1.0">
  <script src="../../js/vue.js"></script>
  <title>關於v-for的key</title>
</head>
<body>
  <div id="app">
    <div>
      <input type="text" v-model="name">
      <button @click="add">新增</button>
    </div>
    <ul>
      <li v-for="(item,index) in list" :key="item.id">
        <input type="checkbox"> {{item.name}}
      </li>
    </ul>
  </div>
  <script type="text/script">
    const app = new Vue({
      el: '#app',computed: {
      },});
  </script>
vjeycBulJj
<style scoped> </style> </body> </html>

在這裡插入圖片描述

在這裡插入圖片描述

在我們選中李四並新增趙六後,被選中的人還是 李四,沒有變化。

這是因為vue底層的Diff演算法導致的。diff演算法的處理方法是對操作前後的dom樹同一層的節點進行對比,一層一層對比,如下圖:

在這裡插入圖片描述

當某一層有很多相同的節點時,也就是列表節點時,Diff演算法的更新過程預設情況下也是遵循以上原則。

比如一下這個情況:

在這裡插入圖片描述

我們希望可以在B和C之間加一個F,Diff演算法預設執行起來是這樣的:

在這裡插入圖片描述

http://www.cppcns.com把C更新成F,D更新成C,E更新成D,最後再插入E,是不是很沒有效率?

所以我們需要使用key來給每個節點做一個唯一標識,Diff演算法就可以正確的識別此節點,找到正確的位置區插入新的節點。

在這裡插入圖片描述

vue中列表迴圈需加:key=“唯一標識” 唯一標識可以是item裡面id index等,因為vue元件高度複用增加Key可以標識元件的唯一性,為了更好地區別各個元件 key的作用主要是為了高效的更新虛擬DOM。

總結

本篇文章就到這裡了,希望能夠給你帶來幫助,也希望您能夠多多關注我們的更多內容!