怎么避免按钮组件闪现-watch监听实践

第一次打算在掘金上发表文章,想一想还是从自己最近的一次业务需求上入手,写一个watch监听的使用,小试牛刀。有写的不对的地方,还请各位看官多多指证。

  • 先说一说需求是什么:业务侧要求图文标签命中敏感词的时,有一个【关注按钮】不要展示。
  • 接到需求后,我想这简单呀,组件上加上v-if解决了。然而效果是有了,但是体验并不好。具体分析原因是,获取标签敏感词是一个异步接口返回的,导致呈现的效果是,拿到敏感词且匹配命中前,【关注按钮】会先展示,敏感词匹配命中后,【关注按钮】才会消失。所以呈现出了【关注按钮】一闪而过的效果,这多少有点影响用户体验呀~~
  • 虽然产品小姐姐没有说什么,但是本着让小姐姐一眼满意的想法💡,还是打算再动手优化一下,优化步骤往下看⬇️
  1. -给关注按钮添加一层父div包裹,父div加上v-show,默认false不展示。
  2. 当获取标签敏感词且得到匹配结果后,父div v-show=true,展示。
  3. 优化完成,再看下结果➡️乖乖~ 命中敏感词后,没有闪现,【关注按钮】不展示了,完美。。。
  4. 等等,作为一名严谨的开发,咱怎么可以只测一条用例呢?必须再测一条!
  5. 发现标签敏感词未命中后,【关注按钮】也没有展示😭
sql 复制代码
> - 这问题值得分析一下,父div的v-show值是取的监听,监听【关注按钮】v-if 的值,通过日志打印和页面元素查看,发现v-if 的值变为false后,没有走入监听函数,所以父div的v-show值没有改变,还是false默认值。

既然是 监听函数没有处理,那是不是watch函数的原因呢?来来,我们看看

原来watch监听要有值变化,才会触发监听函数。而【关注按钮】v-if的默认值,我给的是false,改成null后,就好了。这样命中敏感词是true,没有命中敏感词是false,都能走进watch 的监听函数 🥳

ps:文中代码都是简易表述,是针对相关需求做的陈述。主要还是为了说明 watch监听函数的使用,有时会忽略状态的默认值问题,导致走不进监听函数。

相关推荐
漂流瓶jz6 小时前
Webpack如何实现万物皆可import?loader的使用/配置/手写实践
前端·javascript·webpack
ZC跨境爬虫7 小时前
跟着 MDN 学CSS day_41:显式轨道、隐式网格与区域命名放置
前端·javascript·css·ui·交互
修己xj7 小时前
告别手动存图!这款叫 Fatkun 的浏览器插件,简直是素材收集神器
前端
袋鼠云数栈8 小时前
从前端到基础设施,ACOS 如何打通企业全链路可观测
运维·前端·人工智能·数据治理·数据智能
AskHarries8 小时前
系统提示词、开发者指令和用户输入的优先级
java·前端·数据库
Moment8 小时前
长上下文会最终杀死 Rag 吗?
前端·javascript·后端
qcx239 小时前
【系统学AI】25 论文导读 ①:两篇改变 AI 的开山之作——Attention Is All You Need & ReAct
前端·人工智能·react.js·transformer
kyriewen10 小时前
大文件上传最全指南:分片、断点续传、秒传,一篇就够了
前端·javascript·面试
郑洁文11 小时前
基于Python的Web命令执行漏洞自动化检测系统
前端·python·网络安全·自动化
新酱爱学习11 小时前
手搓 10 个 Skill 后,我把重复劳动收敛成了一套零依赖 CLI 工具
前端·javascript·人工智能