【第26题】vue for循环中key有什么作用
前端名狮
共 636字,需浏览 2分钟
· 2022-04-16
题目描述:
无论是react还是vue框架,在列表渲染时都会提示或者要求每个列表项使用唯一的key。这个key有什么作用?如何正确设置value呢?
答案解析:
这道题目实际考察的是对虚拟dom对象中diff算法的理解。
diff算法的本质是:找出新旧两个虚拟dom对象之间的差异,目的是尽可能复用节点,提高性能。
key的主要作用就是在diff算法中判断新旧节点是否是同一类型,从而复用与新节点对应的老节点,节约性能的开销
export function isSameVNodeType(n1: VNode, n2: VNode): boolean {
return n1.type === n2.type && n1.key === n2.key
}
举个反面的例子理解下,我们经常使用数组的index作为列表的key使用,看下具体的流程哈
如果是顺序增加元素,顺序不会乱,所以不会造成影响,可以正常使用;
如果存在列表删除、元素间对换的话,因为key(index)是一样的,新节点顺序和老节点顺序仍然是从前往后一一对应的,但是通过对节点的内容进行判断,元素内容实际已经变化,是需要一次内容更新的,这就造成了一次性能开销。在chrome调试工具中是可以观察到节点内容变化的,有兴趣的可以尝试下。
顺便推荐一篇讲diff算法的文章,感觉是我读到的写的最清晰的一篇:vue-diff算法解析
关注我
关注我的公众号【前端名狮】,更多精彩内容陪伴你!
评论
什么是电子名片,有什么作用?
纸质名片(传统小卡片)
纸质卡片,上面印有个人的姓名、地址、职务、电话号码、邮箱、单位名称、职业等。也是向对方推销介绍自己的一种方式。名片是新朋友互相认识、自我介绍的最快有效的方法。交换名片是商务交往的第一个标准仪式动作。使用场景:面对面交换纸质名片
电子名片(信息化名片)
图片格式卡片,把纸质名片转为图片格式,上面同样有个人的姓名、地址、职务、电话号码、邮箱、单位名称、职业等。电子名片是随着移动互联网的出现而出现,随着微信等社交软件的普及而普及。使用场景: 微信好友交换图片名片
数字化名片(智能化名片)
数字化卡片,把图片电子名片数字化,上面同样有个人的姓名、地址、职务、电话号码、邮箱、单位、职业等等。数字名片随着微信小
名片活动行
0
什么是电子名片,有什么作用?
电子名片也叫数字名片或者智能名片,有以下的一些特点:
1,现在市面上的电子名片基本上都是基于微信平台开发的。有H5,小程序等体现方式。
2,现在由少数公司在开发基于抖音的电子名片,但是从社交、销售的角度分析,微信的社交功能会更强大些。
3,基于微信开发的电子名片小程序,做的好我们认为有几个特点:带官网+可追踪客户+能获客。这样的功能就完全突破了纸质名片的能力了。
4,在展示方便,一个词可以形容:立体展示!为什么啦?电子名片可以展示文字、图片、视频、声音、链接跳转等。这些是纸质名片不具备的。
5,传播上。纸质名片必须面对面的赠送才可以。而电子名片。基于微信的生态流量,可以在微信群,朋友圈、个人、企业微信客户的无限制的转发。分
欧铂猎手智能电子名片
0