这就是用index作为key的弊端所在了,索引是基于数组的顺序,而不是基于每个项的内容。如果列表中的项目发生了变化,例如向列表头部或者中间添加或删除了某个项目,这会导致相同的索引对应着不同的项,这样就会破坏Vue的虚拟DOM Diff算法,使得整个列表被浏览器重新渲染,性能大大的降低了...
<!-- 内容 --> key 的必要性 Vue 默认按照“就地更新”的策略来更新通过 v-for 渲染的元素列表。当数据项的顺序改变时,Vue 不会随之移动 DOM 元素的顺序,而是就地更新每个元素,确保它们在原本指定的索引位置上渲染。 为了避免上述情况,可以为每个元素对应的块提供一个唯一的 key attribute。 这个特殊的 key...
如果不存在key,则遍历剩余 oldCh,获取index;=> findIdxInOld 判断是否索引到 index 【情况1】没有索引到,说明无法复用老的,直接新建; 【情况2】索引到了,如果是相同的节点,直接移动; 【情况3】索引到了,只是key相同,但节点发生了变化,直接新建; --- 至此,直到上述循环结束,oldStartIdx > oldEndIdx |...
而在使用v-for指令时,通常会需要给每个遍历的元素指定一个唯一的key值,以帮助Vue更高效地更新DOM。 在很多情况下,我们可能会倾向于使用index作为key值,因为index默认就是唯一的。但是,Vue官方不推荐使用index作为key值的原因主要有以下几点: 状态不稳定:在Vue的开发中,数据是动态变化的,当数据发生变化时,新的元素...
vue v-for中key的作用,使用index作为key会怎么样? 原理# 其主要的目的就是优化性能。vue在更新dom时会比较key值相同的元素内容是否发生改变,如果不变则不更新页面,这样可以使得尽可能减少页面的更新,提高性能。假如我渲染3个元素,不设置key值,即默认策略应该是标识为index,即0,1,2。假如我在第一个元素后加一个...
Vue模板中使用v-for指令时不建议将index作为:key属性。今天我在看项目代码时,发现有多年开发经验的前端老鸟也犯这样的低级错误。 今天我们就从其原理上说明为什么不建议将index作为v-for的key,除非你能确定该v-for遍历的数组长度始终不会发生变化,不过在这个需求多变的时代谁能保证产品不会想一出是一出呢?
前言 在vue中使用v-for时需要,都会提示或要求使用 :key,有的的开发者会直接使用数组的 index 作为 key 的值,但不建议直接使用 index作为 key 的值,有时我们面试时也会遇到面试官问:为什么不推荐使用 index 作为 key ?接下来和小颖一起来瞅瞅吧 为什么要有 key
2. 用 v-for 在一个范围内进行循环 虽然大多数情况下 v-for 用于遍历数组或对象,但肯定存在我们可能只想迭代特定次数的情况。假设我们要网店创建一个分页系统,并且想在每页只显示 10 个商品品。通过使用变量来跟踪我们当前的页码,可以像这样处理分页:looping over a range {{ products[page * 10 + ...
可以用index作为key吗? 这个问题相信不陌生了,使用过vue的童鞋都接触过。狗子最近在复习,顺带帮大家一起回忆一下。 先说答案,因为绑定key值是为了,渲染虚拟dom时用key作为标识,做到局部更新。 不使用index作为key是因为 列表更新时index对应也会改变,唯一标识发生变化,导致渲染时依然会整体渲染,比较浪费性能。
此时,list 的 item 作为 select 的选项,也不会出现上面所描述的bug。 “vue中使用v-for时为什么不可以使用index作为key的原因”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!