内容简介:今天探讨一个我们前端面试中经常会遇到的一个问题.使用初学者开发过程中, 可能很难理解
今天探讨一个我们前端面试中经常会遇到的一个问题.
使用 index
作为 key
值有什么问题呢? 在我们日常开发中我们经常会和 key
值打交道. 但是我们扪心自问, 真的理解 key
吗? 我想大多数朋友可能会有些许犹豫.
初学者开发过程中, 可能很难理解 key
值存在的意义. 我们可以简单把它理解为每一条数据的唯一标识. 它与这条数据是关联在一起的. 能理解到这个地方就足够了.
那么为什么不建议使用 index
作为 key
值呢?
如图所示:
上面这个列表我们使用下标 ( index
) 作为 key
值. 其对应关系如图
此时页面显示是没有问题的, 控制台也不会报错.
但是
假设此时我们删除 List
中的第 2 项内容 (虚拟 DOM
很简单). 我们来看看会有什么效果?
能不能发现两个 List
所发生的变化?
我们仔细来看:
当我们删除了原来 list
中的 下标为 1 的数据 ( 虚拟 DOM 很简单 之后). 可以看到除了第一项数据的下标没有发生变化, 其余数据的下标都发生了变化
那么问题随之而来:
原来的数据之中:
- Diff 算法好理解 - > 2
- 文字叙述不麻烦 -> 3
- 理解起来更容易 -> 4
它们使用下标作为 key
值, 随着页面的重新渲染, key
值也发生了变化
- Diff 算法好理解 - > 1
- 文字叙述不麻烦 -> 2
- 理解起来更容易 -> 3
导致的问题就是以前的数据和重新渲染后的数据随着 key
值的变化从而没法建立关联关系. 这就失去了 key
值存在的意义. 也是导致数据出现诡异的罪魁祸首!
开发过程中, 因为我们的数据绝大部分都是从后台获取来的. 数据库中每一条数据都会一个 id
. 作为唯一标识. 而这个 id
也是我们最常使用作为 key
值来源
最后说明: 一定要避免使用 index
作为 key
值得编码习惯. 切记! 切记!
以上所述就是小编给大家介绍的《简单通透理解: 为什么不建议使用 index 作为 key 值》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 使用Elasticsearch作为主数据存储
- 如何把MongoDB作为循环队列
- 使用 utterances 作为博客评论组件
- 作为项目经理应该串联起哪些流程
- 作为产品经理,如何做好项目管理?
- 如何面试-作为面试官得到的经验
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
旷世之战――IBM深蓝夺冠之路
纽伯 / 邵谦谦 / 清华大学出版社 / 2004-5 / 35.0
本书作者Monty Neworn是国际计算机象棋协公的主席,作者是用生动活泼的笔触描写了深蓝与卡斯帕罗夫之战这一引起全世界关注的历史事件的前前后后。由于作者的特殊身份和多年来对计算机象棋的关心,使他掌握了许多局外人不能得到的资料,记叙了很多鲜为人知的故事。全书行文流畅、文笔优美,对于棋局的描述更是跌宕起伏、险象环生,让读者好像又一次亲身经历了那场流动人心的战争。 本书作为一本科普读物......一起来看看 《旷世之战――IBM深蓝夺冠之路》 这本书的介绍吧!