简单通透理解: 为什么不建议使用 index 作为 key 值

简介: 云栖号资讯:【点击查看更多行业资讯】在这里您可以找到不同行业的第一手的上云资讯,还在等什么,快来! 今天探讨一个我们前端面试中经常会遇到的一个问题。 使用 index 作为 key 值有什么问题呢? 在我们日常开发中我们经常会和 key 值打交道。

云栖号资讯:【点击查看更多行业资讯
在这里您可以找到不同行业的第一手的上云资讯,还在等什么,快来!


今天探讨一个我们前端面试中经常会遇到的一个问题。

使用 index 作为 key 值有什么问题呢? 在我们日常开发中我们经常会和 key 值打交道。但是我们扪心自问, 真的理解 key 吗? 我想大多数朋友可能会有些许犹豫。

初学者开发过程中,可能很难理解 key 值存在的意义。我们可以简单把它理解为每一条数据的唯一标识,它与这条数据是关联在一起的, 能理解到这个地方就足够了。

那么为什么不建议使用 index 作为 key 值呢?

1

如图所示:

上面这个列表我们使用下标 (index) 作为 key 值,其对应关系如图

此时页面显示是没有问题的, 控制台也不会报错。

但是

假设此时我们删除 List 中的第 2 项内容 (虚拟 DOM 很简单). 我们来看看会有什么效果?

2

能不能发现两个 List 所发生的变化?

我们仔细来看:

当我们删除了原来 list 中的下标为 1 的数据 (虚拟 DOM 很简单 之后). 可以看到除了第一项数据的下标没有发生变化,其余数据的下标都发生了变化.

那么问题随之而来:

原来的数据之中:

1.Diff 算法好理解 - > 2

2.文字叙述不麻烦 -> 3

3.理解起来更容易 -> 4

它们使用下标作为 key 值, 随着页面的重新渲染, key 值也发生了变化

1.Diff 算法好理解 - > 1

2.文字叙述不麻烦 -> 2

3.理解起来更容易 -> 3

导致的问题就是以前的数据和重新渲染后的数据随着 key 值的变化从而没法建立关联关系。这就失去了 key 值存在的意义,也是导致数据出现诡异的罪魁祸首!

开发过程中, 因为我们的数据绝大部分都是从后台获取来的。数据库中每一条数据都会一个 id ,作为唯一标识, 而这个 id 也是我们最常使用作为 key 值来源。

【云栖号在线课堂】每天都有产品技术专家分享!
课程地址:https://yqh.aliyun.com/zhibo

立即加入社群,与专家面对面,及时了解课程最新动态!
【云栖号在线课堂 社群】https://c.tb.cn/F3.Z8gvnK

原文发布时间:2020-04-11
本文作者:王道_
本文来自:“掘金”,了解相关信息可以关注“掘金”

相关文章
|
13天前
|
JavaScript 索引
V-for中 key 值的作用,如何选择key
V-for中 key 值的作用,如何选择key
|
2月前
|
小程序
小程序for循环中key值的作用?
小程序for循环中key值的作用?
|
21天前
|
JavaScript 索引
V-for中key值的作用,如何选择key
V-for中key值的作用,如何选择key
|
8月前
|
JavaScript 算法 索引
v-for中key值的作用
v-for中key值的作用
|
7月前
|
小程序 JavaScript 索引
小程序v-for与key值使用
小程序v-for与key值使用
116 0
数组把key相同值,合并value值(整理)
数组把key相同值,合并value值(整理)
|
8月前
|
前端开发
根据key值过滤形成新得数组
根据key值过滤形成新得数组
49 0
|
9月前
|
存储 缓存 NoSQL
【原创】详细案例解剖——浅谈Redis缓存的常用5种方式(String,Hash,List,set,SetSorted )
【原创】详细案例解剖——浅谈Redis缓存的常用5种方式(String,Hash,List,set,SetSorted )
|
XML 前端开发 Java
SSM框架@Value("${key}")不能获取属性,原样输出${key}的分析
今天在做框架改造时,碰到了不能@Value 不能获取属性的问题。纠结了好一阵,现做一个简单记录。
151 0
|
存储 Java
从数组当做map的key引发的思考
从数组当做map的key引发的思考
117 0