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

栏目: IT技术 · 发布时间: 5年前

内容简介:今天探讨一个我们前端面试中经常会遇到的一个问题.使用初学者开发过程中, 可能很难理解

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

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

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

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

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

如图所示:

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

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

但是

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

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

能不能发现两个 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 值来源

最后说明: 一定要避免使用 index 作为 key 值得编码习惯. 切记! 切记!


以上所述就是小编给大家介绍的《简单通透理解: 为什么不建议使用 index 作为 key 值》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

数文明

数文明

涂子沛 / 中信出版集团 / 2018-9 / 88.00元

从量数、据数、普适记录、人脸识别、以图搜车,到雾计算、城市大脑、单粒度治理、无匿名社会、量子思维……作为中国研究大数据的权威专家,作者在《数文明》一书中,以大数据为核心元素,抽丝剥茧,深入地阐述了这个大数据时代的文明社会——一个全新的数文明时代。 将大数据与人类文明融合在一起,这本书提供给我们的不仅是一种全新的叙事结构,它还将突破你的认知边界和思维极限,给你提供一个应对这个世界的全新的认知方......一起来看看 《数文明》 这本书的介绍吧!

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具