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

相关推荐
Pu_Nine_91 天前
IntersectionObserver 详解:封装 Vue 指令实现图片懒加载
前端·javascript·vue.js·性能优化
前端那点事1 天前
Vue nextTick 超全解析|作用、使用场景、底层原理、Vue2/Vue3区别
前端·vue.js
前端那点事1 天前
Vue面试高频:子组件能直接修改父组件数据吗?单向数据流原理+正确写法全覆盖
前端·vue.js
前端那点事1 天前
为什么 Vue 的 template 标签不能用 v-show?底层机制+踩坑复盘+生产级解决方案
前端·vue.js
北风toto1 天前
为什么 IntelliJ IDEA Community 无法开发 Vue?——附解决方案
java·vue.js·intellij-idea
跟着珅聪学java1 天前
Element UI 的 Tabs 标签页开发教程
javascript·vue.js·elementui
jiayong231 天前
前端面试题库 - Vue框架篇
前端·vue.js·面试
三*一1 天前
Mapbox GL JS 前端多边形分割实战:从踩坑到优雅实现
开发语言·前端·javascript·vue.js
xChive1 天前
前端请求取消:用 AbortController 从 fetch 到 axios
前端·vue.js·axios·fetch·abortcontroller
踩着两条虫1 天前
AI 低代码引擎可视化设计器交互机制实战
前端·vue.js·人工智能·低代码·架构