--- 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树,这在增删情况下就减少了不少的开销

相关推荐
killerbasd10 小时前
牧苏苏传 我不装了 4/7
前端·javascript·vue.js
大家的林语冰12 小时前
《前端周刊》尤大开源 Vite+ 全家桶,前端工业革命启动;尤大爆料 Void 云服务新产品,Vite 进军全栈开发;ECMA 源码映射规范......
前端·javascript·vue.js
M ? A14 小时前
Vue 迁移 React 实战:VuReact 一键自动化转换方案
前端·vue.js·经验分享·react.js·开源·自动化·vureact
Burt14 小时前
我的 2026 全栈选型:Vue3 + Elysia + Bun + AlovaJS
vue.js·全栈·bun
小锋java123414 小时前
SpringBoot 4 + Spring Security 7 + Vue3 前后端分离项目设计最佳实践
java·vue.js·spring boot
一 乐14 小时前
校园线上招聘|基于springboot + vue校园线上招聘系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·校园线上招聘系统
LanceJiang14 小时前
从输入 URL 到页面:一个 Vue 项目的“奇幻漂流”
vue.js
码喽7号15 小时前
vue学习四:Axios网络请求
前端·vue.js·学习
像素之间16 小时前
为什么运行时要加set NODE_OPTIONS=--openssl-legacy-provider && vue-cli-service serve
前端·javascript·vue.js
M ? A16 小时前
Vue转React实战:defineProps精准迁移实战
前端·javascript·vue.js·经验分享·react.js·开源·vureact