日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當前位置:首頁 > 科技  > 軟件

小紅書面試:v-for循環,為什么不建議使用index作為key?

來源: 責編: 時間:2024-04-24 17:31:44 179觀看
導讀Hello,大家好,我是 Sunday。最近有個同學在小紅書三面的時候遇到了一個面試題:“v-for循環,為什么不建議使用index作為key?”按說這個問題并不復雜,所以該同學直接回答:“使用 index 作為 key 可能會導致渲染性能問題,特別是

Hello,大家好,我是 Sunday。8Bx28資訊網——每日最新資訊28at.com

最近有個同學在小紅書三面的時候遇到了一個面試題:“v-for循環,為什么不建議使用index作為key?”8Bx28資訊網——每日最新資訊28at.com

按說這個問題并不復雜,所以該同學直接回答:“使用 index 作為 key 可能會導致渲染性能問題,特別是數據源使用了 unshift 將數據添加到頭部時,會導致 index 被重新規劃,從而導致重新渲染。”8Bx28資訊網——每日最新資訊28at.com

然后面試官繼續追問:“為什么 index 變化了就會導致 dom 重新渲染?它的渲染機制是什么?”8Bx28資訊網——每日最新資訊28at.com

額... 吃了沒有看過源碼的虧,導致這個問題并沒有回答出來(但愿該同學這次小紅書面試可以順利通過,畢竟都到技術三面了)。8Bx28資訊網——每日最新資訊28at.com

所以,咱們今天就針對這個面試題來說一下。8Bx28資訊網——每日最新資訊28at.com

v-for 循環的渲染時機

在 Vue 的渲染中,有兩個比較重要的渲染時機:渲染、更新。8Bx28資訊網——每日最新資訊28at.com

  • 渲染:指的是 DOM 的首次渲染。首次的渲染性能的消耗是固定的。
  • 更新:指的是 數據變化后影響到的視圖變化,所謂的性能問題,主要就集中在這里。

我們以這段代碼為例,以下代碼表示的就是一段 更新 的邏輯:8Bx28資訊網——每日最新資訊28at.com

<template> <div>  <ul>   <li v-for="(item, index) in list" :key="index">{{ item }}</li>  </ul>  <button @click="change">change</button> </div></template><script setup>const list = ref([1, 2, 3])const change = () => { list.value = [3, 2, 1]}</script>

如果我們把 [1, 2, 3] 作為一組 dom,把 [3, 2, 1] 作為另外一組 dom,那么 dom 由 [1, 2, 3] 變成 [3, 2, 1] 的過程就是 DOM 更新。8Bx28資訊網——每日最新資訊28at.com

key 在渲染中的作用

同時,我們需要注意:針對于 v-for 的 dom 更新,一定是:兩組 dom 對比發生的變化。8Bx28資訊網——每日最新資訊28at.com

而在 vue 中,一旦兩組 dom 對比更新,那么就會觸發 diff 算法 的邏輯,而在 diff 中有這樣一段 vue 的源代碼 isSameVNodeType:8Bx28資訊網——每日最新資訊28at.com

圖片圖片8Bx28資訊網——每日最新資訊28at.com

這段代碼是用來判斷 兩個 DOM 是否相等的。8Bx28資訊網——每日最新資訊28at.com

它的判斷條件有兩個:8Bx28資訊網——每日最新資訊28at.com

  1. type:表示當前 dom 的類型,比如:li、div、p 等不同標簽名
  2. key:v-for 循環中綁定的 key 值

那么由此我們就可以知道:在 vue 中,通過 type + key 兩個屬性來判斷 dom 是否相等。8Bx28資訊網——每日最新資訊28at.com

如果條件滿足(isSameVNodeType 返回 true),那么就不會重新渲染 dom,從而可以 提升性能8Bx28資訊網——每日最新資訊28at.com

index 為什么會影響性能?

根據上面的內容,我們可以知道:在 type 不變的前提下,key 就決定了 dom 是否要重新渲染。8Bx28資訊網——每日最新資訊28at.com

假如,我們使用 index 作為 key,同時使用 unshift 方法為數組添加了一個新的元素,那么所有的 index 都會發生變化,從而導致:isSameVNodeType 返回 false,即:所有的 dom 全部重新渲染 從而影響性能8Bx28資訊網——每日最新資訊28at.com

本文鏈接:http://www.www897cc.com/showinfo-26-85223-0.html小紅書面試:v-for循環,為什么不建議使用index作為key?

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: 十個每個程序員都應該知道的JavaScript技巧

下一篇: 大白話講解Rust中令人頭痛的“所有權”

標簽:
  • 熱門焦點
Top 主站蜘蛛池模板: 阿鲁科尔沁旗| 喀喇沁旗| 桐柏县| 郸城县| 神池县| 灵山县| 镇平县| 四平市| 新乡市| 泰安市| 外汇| 岳阳市| 南开区| 楚雄市| 西盟| 西峡县| 定南县| 佛冈县| 思南县| 西吉县| 历史| 四川省| 筠连县| 年辖:市辖区| 邵阳县| 镇赉县| 阜康市| 平塘县| 轮台县| 临沭县| 兴城市| 沁水县| 久治县| 岐山县| 五莲县| 威信县| 保亭| 七台河市| 拜城县| 武强县| 吕梁市|