Ant Design Vue (2x) 按钮(button)单击后离开,按钮状态无变化

Ant Design Vue (2x) 按钮(button)单击后离开,按钮状态无变化

场景:

使用Ant Design 2x 开发,在使用<a-button> 时,鼠标浮上,按钮高亮,摁下后依然高亮,鼠标松开并离开后高亮依然显示。

问题:

上面的场景与我想要的不一样,鼠标浮上和摁下后高亮是我们需要的,但是我鼠标都松开而且离开按钮了,你还高亮,这就有问题了啊。 时间证明这的确是一个问题,因为我发现在后面的版本 4x 中这个问题已经被解决了。

解决方案

  1. 更新版本到 4x,但是对于一个项目来说,UI库的版本更新,会存在很多隐藏的问题。
  2. 自己解决。

我的方案:

我经过更新版本的风险评估后,感觉我还是自己解决更安全一些,承担不了更新后出现的不确定性问题带来的后果。

分析问题:

鼠标离开按钮后,高亮没有消失,两种情况

  1. hover样式一直存在
  2. focus样式一直存在

定位问题:

通过分别设置 :hover 和 :focus 的样式来定位是哪个属性

css 复制代码
:deep(.ant-btn:hover){
    color:red
  }
  :deep(.ant-btn:focus){
    color:green
  }

经过实验发现,是鼠标松开离开后,focus属性依然存在

解决问题:

在鼠标松开后,手动移除Ant Design 库中 的focus属性

实际应用:

  1. 给 通过ref进行标记
ini 复制代码
  <a-button  ref="btnRef"  @mouseup="handleMouseUp()" > </a-button>
  1. 在mouseup时,通过blur()方法移除focus
ini 复制代码
	cosnt btnRef = ref(null)
 	const handleMouseUp = () => {
		btnRef.value?.$el?.blur();
	}

经过上如设置,Ant Design 中按钮鼠标离开高亮不消失的问题就解决了。 如果对你有帮助,请点赞收藏欧,一路生花~~嘿嘿

相关推荐
子兮曰5 小时前
Bun v1.3.14 深度解析:Image API、HTTP/3、全局虚拟存储与五十项变革
前端·后端·bun
kyriewen6 小时前
今天,百年巨头一次砍了9200人,而一个离职科学家的实话让全网睡不着觉
前端·openai·ai编程
问心无愧05136 小时前
ctf show web 入门42
android·前端·android studio
kyriewen6 小时前
老板逼我上AI,我偷偷在浏览器里跑LLaMA,省下20万API费
前端·react.js·llm
Beginner x_u7 小时前
前端八股整理(手写 02)|数组转树、数组扁平化、随机打乱一个数组
前端·数组·数组转树·数组扁平化
KaMeidebaby7 小时前
卡梅德生物技术快报|禽类成纤维细胞 FISH 实验:鸟类性别染色体基因定位技术实现与数据验证
前端·数据库·其他·百度·新浪微博
天若有情6737 小时前
前端高阶性能优化:跳出传统懒加载与预加载,基于用户行为做轻量预判加载
前端·性能优化
小小小小宇7 小时前
前端转后端:SQL 是什么
前端
张元清8 小时前
React Observer Hooks:7 种监听 DOM 而不写样板代码的方式
前端·javascript·面试
广州华水科技8 小时前
单北斗GNSS变形监测是什么?主要有怎样的应用与优势?
前端