91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在Vue頁面渲染中使用key

發布時間:2021-01-13 14:37:41 來源:億速云 閱讀:287 作者:Leah 欄目:開發技術

這期內容當中小編將會給大家帶來有關怎么在Vue頁面渲染中使用key,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

問題分析

通過閱讀代碼結構,發現el-table-column通過template循環生成,由于template的作用是模板占位符,可幫助我們包裹元素,但在循環過程當中,template不會被渲染到頁面上。有關表格數據渲染中key的作用如下:

  • key作為一個DOM節點的標識值,結合Diff算法可以實現對節點的復用。(key相同的節點會被復用);

  • 只有當key(或其他導致isSameNode判斷為false)發生改變時,才會觸發節點的重新渲染。否則Vue將會復用之前的節點,通過改變節點的屬性來實現節點的更新。

同時,template標簽不支持:key屬性,

注意: vue實例綁定的元素內部的template標簽不支持v-show指令,即v-show="false"對template標簽來說不起作用。但是此時的template標簽支持v-if、v-else-if、v-else、v-for這些指令。

解決方法

既然template標簽不支持key屬性,可通過在el-table-column標簽加入:key="Math.random()"屬性,這個key屬性是vue自帶的特殊屬性,主要用在 Vue 的虛擬 DOM 算法,在新舊 nodes 對比時辨識 VNodes,依次來提升頁面渲染性能。如果不更新這個key的話,顯示/隱藏列的時候,部分DOM不會重新渲染,導致table變化時候內容錯亂。

拓展閱讀

一、key的作用

前文已經講到,作為一個DOM節點的標識值,結合Diff算法可實現對節點的復用。(key相同的節點會被復用。)

只有當key(或其他導致isSameNode判斷為false)發生改變時,才會觸發節點的重新渲染。否則Vue將會復用之前的節點,通過改變節點的屬性來實現節點的更新。那么,key使用id與index的區別又是什么呢?

二、key使用id與index的區別

不推薦使用index作為key,因為這種做法會導致某些節點被錯誤地原地復用,具體如下:

  • 性能損耗:列表渲染時會導致變動項往后的所有列表節點(內容)的更新(相當于key沒發揮作用)。

  • 出現錯誤:某些節點在錯誤的位置被復用。(例如當列表項中使用到復選框時)

性能損耗

列表渲染時會導致變動項往后的所有列表節點(內容)的更新(相當于key沒發揮作用)

需要注意的是,變動項往后的所有列表節點的更新本質是節點屬性的更新,節點本身會被復用。

<!-- 測試代碼 -->
<template>
 <div>
 <div v-for="(item, index) in arr" :key="index 或 item.id">
  {{item.data}}
 </div>
 </div>
</template>

<script>
export default {
 name: 'HelloWorld',
 data(){
 return {
  arr: Array.from({length: 10000}, (v, i) => {return {id: i, data: i}})
 }
 },
 mounted(){
 setTimeout(()=>{
  /* 
  1. this.shiftArr()	// 刪除首項
  或
  2. this.unShiftArr()	// 在首部插入新項
  */
 }, 1000)
 },
 methods: {
 shiftArr(){
  this.arr.shift();
 },
 unshiftArr(){
  this.arr.unshift({id: -1, data: -1});
 }
 }
}
</script>

上邊的例子很簡單,就是v-for渲染一個長度為10000的列表,然后在Vue mounted 1s后,執行一個刪除列表首項或在列表頭插入新項,觀察兩種key綁定的具體頁面更新開銷。

頁面開銷使用chrome的performance選項卡來測算

刪除列表首項

怎么在Vue頁面渲染中使用key

列表頭 unshift 新元素

怎么在Vue頁面渲染中使用key

出現錯誤

某些節點在錯誤的位置被復用。(例如當列表項中使用到復選框時)

<!-- 測試代碼 -->
<template>
 <div>
 <button @click="test">刪除列表第一項</button>
 <div v-for="(item, index) in arr" :key="index 或 item.id">
  <input type="checkbox" />
  {{item.data}}
 </div>
 </div>
</template>

<script>
export default {
 name: 'HelloWorld',
 data(){
 return {
  arr: Array.from({length: 5}, (v, i) => {return {id: i, data: i}})
 }
 },
 methods: {
 test(){
  this.arr.shift();
 }
 }
}
</script>

上述就是小編為大家分享的怎么在Vue頁面渲染中使用key了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

容城县| 贵州省| 兰溪市| 东辽县| 璧山县| 景洪市| 麦盖提县| 安义县| 南昌市| 海口市| 德昌县| 湘乡市| 合肥市| 和田市| 崇阳县| 晋中市| 陆丰市| 高安市| 股票| 当阳市| 民勤县| 龙里县| 揭阳市| 芒康县| 离岛区| 阿城市| 浮梁县| 丹巴县| 施秉县| 九寨沟县| 玉树县| 韩城市| 曲松县| 合水县| 博白县| 射洪县| 舞阳县| 盱眙县| 抚宁县| 剑河县| 青阳县|