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


相关推荐
需要兼职养活自己几秒前
react【portals】与vue3【<Teleport>】
前端·react.js
用户47949283569152 分钟前
React 19.2 重磅更新:终于解决 useEffect 依赖数组难题
前端·react.js
梦里小白龙8 分钟前
前端视频课程添加水印,全屏不消失解决方法
前端·音视频
我命由我1234513 分钟前
PDFBox - PDDocument 与 byte 数组、PDF 加密
java·服务器·前端·后端·学习·java-ee·pdf
@PHARAOH14 分钟前
HOW - prefetch 二级页面实践
前端·javascript·react.js
EF@蛐蛐堂16 分钟前
WUJIE VS QIANKUN 微前端框架选型(一)
前端·vue.js·微服务·架构
咚咚咚小柒23 分钟前
【前端】用el-popover做通用悬停气泡(可设置弹框宽度)
前端·javascript·vue.js·elementui·html·scss
Ares-Wang24 分钟前
CSS3》》 transform、transition、translate、animation 区别
前端·css·css3
fsnine37 分钟前
Python Web框架对比与模型部署
开发语言·前端·python
广州华水科技1 小时前
单北斗GNSS形变监测系统在桥梁安全中的应用与技术解析
前端