--- vue标签中有key和没有的区别 ---

vue key

vue在给标签加上key之后能增加,增加和删除的性能

vue在更新时会尽量使用原来的dom来进行修改

如果没有添加key

vue会创建虚拟的dom结点来和真实的dom节点一一对比看哪里修改了,如果没有节点的增删,那么他的效率其实和使用key是一样的,但是如果有了增删,那就不一样了,比如头插了一个元素,这时虚拟节点是a b c ,而实际dom节点是b c ,vue会尽量使用原来的dom元素,那么会在比较第一个虚拟和实际dom节点时,发现虚拟头dom a 和 实际b的不一样了,那就修改,让后继续玩下修改,结果错位了,然后就发现全不一样,于是就涉及到了整颗dom树的修改,在最后c时发现没有实际的dom树了,就才创建一个新的dom树,这就造成了特别大资源浪费

再有key的情况

vue会先比较虚拟dom树和实际dom树key的不同,对于相同的key就直接使用原来的dom节点,并且会比较树中的元素,对元素进行单独修改,对key不同的就创建新的dom树,这在增删情况下就减少了不少的开销

相关推荐
计算机毕设VX:Fegn08951 天前
计算机毕业设计|基于springboot + vue医院设备管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
北辰alk1 天前
Vue 路由信息获取全攻略:8 种方法深度解析
vue.js
北辰alk1 天前
Vue 三剑客:组件、插件、插槽的深度辨析
vue.js
北辰alk1 天前
Vue Watch 立即执行:5 种初始化调用方案全解析
vue.js
北辰alk1 天前
Vue 组件模板的 7 种定义方式:从基础到高级的完整指南
vue.js
北辰alk1 天前
深入理解 Vue 生命周期:created 与 mounted 的核心差异与实战指南
vue.js
计算机毕设VX:Fegn08951 天前
计算机毕业设计|基于springboot + vue小型房屋租赁系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
北辰alk1 天前
Vuex日渐式微?状态管理的三大痛点与新时代方案
vue.js
无羡仙1 天前
Vue插槽
前端·vue.js
狗哥哥1 天前
🔥 Vue 3 项目深度优化之旅:从 787KB 到极致性能
前端·vue.js