Vue指令:记录一次v-if与v-show使用时的真实bug场景

v-if与v-show的区别

老生常谈的话题了,直接粘贴chatGPT老铁给的答案吧~

问题

最近编码中遇到的一个场景:

点击切换底部tab,由于选中的tab比未选中的大一些,所以选择了transform改变图标的大小,开始的时候我使用v-if切换图标,就出现了一个很神奇的现象(如图),切换时图标会莫名闪烁成很大一个(旋转跳跃它闭着眼),这种bug根本无法根据报错或者debug体现,

原因就是:

v-if在每一次切换时重新渲染了元素,导致transform这种变换型样式在初始时会出现错乱似的闪动,后改成v-show之后,利用display属性实现的显示和隐藏,原有属性不会在切换过程中重新被渲染,这类错误就消失了。

所以:

在正确的时候使用v-show还是很有必要的,以前我在代码中习惯使用v-if做显隐判断操作,后来逐渐在书写中养成了先做分析的习惯,这样的话这种奇奇怪怪的现象也会得到有效的解决。

最后感谢大家的喜欢,如果大家在实操中发现一些有意思的bug请给我留言,我都会一一观看并回复,万分感谢!


相关推荐
勿芮介13 分钟前
【大模型应用】在window/linux上卸载OpenClaw
java·服务器·前端
摸鱼仙人~16 分钟前
前端面试手写核心 Cheat Sheet(终极精简版)
前端
Ashley_Amanda35 分钟前
深入浅出Web Dynpro:SAP企业级Web应用开发全面解析
前端
方安乐38 分钟前
概念:前端工程化实践
前端
kyriewen1 小时前
Flexbox 完全指南:从此告别浮动,拥抱一维战神
前端·css·html
xChive1 小时前
ECharts3D图表 | 3D柱状图和3D饼图实现思路
前端·3d·echarts
HookJames1 小时前
解决Claude Code v2.1.74 官方找不到模型的问题-终结版
前端·chrome
代码煮茶1 小时前
Vite 工程化实战 | 从 0 配置一个企业级前端项目(按需引入 / 环境变量 / 打包优化)
前端·vue.js
程序员Sunday1 小时前
5000 字长文,全网最细的OpenClaw(小龙虾)架构拆解,我建议你认真看完
前端·人工智能
踩着两条虫1 小时前
AI 驱动的 Vue3 应用开发平台 深入探究(九):双向代码转换之处理事件、Props 和指令
前端·vue.js·ai编程