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请给我留言,我都会一一观看并回复,万分感谢!


相关推荐
ZC跨境爬虫13 分钟前
跟着 MDN 学CSS day_32:(Web字体深度解析与实践指南)
前端·javascript·css·ui·html
砍材农夫22 分钟前
物联网 基于netty核心实战-安全tls
java·开发语言·前端·物联网·安全
SEO_juper23 分钟前
JavaScript 渲染:AI 智能体无法读取,直接影响收录
开发语言·前端·javascript·aigc·seo·跨境电商·geo
i220818 Faiz Ul33 分钟前
在线预约导游|基于SSM+vue的在线预约导游系统(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·毕设·在线预约导游系统
ZC跨境爬虫33 分钟前
跟着 MDN 学CSS day_35:浮动布局完全指南
前端·css·ui·html·tensorflow
魔士于安38 分钟前
红色文化馆技术文档
前端·unity·游戏引擎·贴图·模型
何何____41 分钟前
js的数据存储机制
开发语言·前端·javascript·ecmascript
无风听海1 小时前
构建现代 Web 应用的令牌安全体系:Refresh Token Rotation、HttpOnly Cookie 与 Grace Period 全解析
前端·安全
云水一下1 小时前
JavaScript 从零基础到精通系列:对象、数组与 ES6 数据操作利器
前端·javascript
四代水门1 小时前
服务端倒带(Server-Side Rewind)命中判定系统
java·前端·算法