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/vue.js"></script> <title>關(guān)于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> <script type="text/javascript"> 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>關(guān)于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/javascript"> 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>
在我們選中李四并添加趙六后,被選中的人還是 李四,沒有變化。
這是因為vue底層的Diff算法導致的。diff算法的處理方法是對操作前后的dom樹同一層的節(jié)點進行對比,一層一層對比,如下圖:
當某一層有很多相同的節(jié)點時,也就是列表節(jié)點時,Diff算法的更新過程默認情況下也是遵循以上原則。
比如一下這個情況:
我們希望可以在B和C之間加一個F,Diff算法默認執(zhí)行起來是這樣的:
即把C更新成F,D更新成C,E更新成D,最后再插入E,是不是很沒有效率?
所以我們需要使用key來給每個節(jié)點做一個唯一標識,Diff算法就可以正確的識別此節(jié)點,找到正確的位置區(qū)插入新的節(jié)點。
vue中列表循環(huán)需加:key=“唯一標識” 唯一標識可以是item里面id index等,因為vue組件高度復用增加Key可以標識組件的唯一性,為了更好地區(qū)別各個組件 key的作用主要是為了高效的更新虛擬DOM。
總結(jié)
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
使用axios請求時,發(fā)送formData請求的示例
今天小編就為大家分享一篇使用axios請求時,發(fā)送formData請求的示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-10-10vue+vue-router轉(zhuǎn)場動畫的實例代碼
今天小編就為大家分享一篇vue+vue-router轉(zhuǎn)場動畫的實例代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-09-09vue表單驗證你真的會了嗎?vue表單驗證(form)validate
這篇文章主要介紹了vue表單驗證你真的會了嗎?vue表單驗證(form)validate,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-04-04