Vue深入理解之v-for中key的真正作用
目录
- 前言
- 第一种: key 采用 index
- 第二种:key 采用唯一 ID
- 总结
前言 大家应该都知道, v-for 中 key 最常用的绑定方式有两种:
- 第一种用 index
- 第二种用 唯一 id
第一种: key 采用 index 我们先来看看代码
{{ item.text }}.item{ background: orange; }
这里我们渲染了 list 数组,并将 index 作为 key ,然后还添加一个替换数据按钮事件,我们来看看效果
文章图片
当我们点击替换数据 这个按钮时,数据变成这样
文章图片
一切看起来很正常对吧,接下来就是重点了,我们要做点小改动,首先我们先刷新下页面让数据恢复成原来的,然后我们将第二条给手动删掉
文章图片
文章图片
现在仅剩下 33333 和 99999,此时我们去点击替换数据 看看有什么效果
文章图片
咦,它只替换了第一条和第三条,原来的第二条被我们刚刚删掉了,导致 44444 没有渲染出来,这是为啥呢?其实很简单,因为替换数据那批数组的 index 跟第一批数组是一样,Vue 判断是相同后又何必创建 Dom 这种浪费资源的操作呢,所以它并不会给第二条重新创建 Dom ,这便是 index 作为 key 的作用。
Note:表面视图没变化,但数据是有更新的,你去访问 list时,里面还是有三条数据22222,44444, 88888,只要记住 Vue 是以数据为驱动而不是视图。
第二种:key 采用唯一 ID 接下来我们来看下第二种,代码如下
{{ item.text }}.item{ background: orange; }
代码和上面差不多,只是新增了 id 并绑定到 key 里面,
接下来我们参考上面的流程走一遍看看这次有什么不同之处。
文章图片
聪明的你已经看出来了,删掉第二条后,点击调换数据 会生成新的三条出来,而不是两条,原理我相信你也懂了,替换数据的那批 id 与上一批不一样,所以 Vue 比较后发现不同就帮我们生成新的 Dom
以上便是使用 index 和 唯一 id 的明显区别
【Vue深入理解之v-for中key的真正作用】另外,像 唯一id 不止上面这一种绑定方式,我们也可以在 v-for 里面使用 :key="Math.random()" 生成唯一id,但这种会有一些细微的差别,这里笔者就不去举例了,至于使用哪种 key 可以提升性能方面的相关知识不是本章的初衷,读者可以自行到网上搜索,相信你只要能理解上面这两种绑定 key 的作用差别在哪里,那么其它的绑定方式对你来讲一定不是难题。
总结 到此这篇关于Vue深入理解之v-for中key真正作用的文章就介绍到这了,更多相关Vue v-for中key作用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- vue如何监听页面缓存事件
- Android Handler 机制(Hander 机制深入探究问题梳理)
- Vue webAPP首页开发
- 直接报错了(安装vue-cli,无法加载文件 C:UsersAdministratorAppDataRoamingpmvue.ps1,因为在此系统中禁止执行脚本)
- Go GPM的理解 与 runtime包
- Mpvue中使用Vant Weapp组件库
- happen-before原则的理解
- 解决 mpvue 项目使用 vant-weapp 组件库 Uploader 时其中的 after-read 方法回调函数调用不成功
- vue项目中,App.vue如何调用
- Android基础知识再次理解