搜索
首页web前端css教程在支持触摸的环境中,我们如何消除按钮上的粘滞悬停效果?

How Can We Eliminate Sticky Hover Effects on Buttons in Touch-Enabled Environments?

消除支持触摸的环境中按钮上的粘性悬停效果

按钮上普遍存在的悬停效果在触摸时会产生问题设备。悬停状态通常由颜色变化表示,即使在点击按钮后也往往会持续存在,从而产生“粘性”效果。这种行为可能是不受欢迎的,并且会影响用户体验。

为了解决这个问题,人们提出了多种方法,并取得了不同程度的成功:

  • 添加“no- touchend 上的“hover”类: 虽然此方法有效地防止了点击后的悬停效果,但它会对性能产生负面影响,并且无法处理同时具有触摸屏和鼠标的设备
  • 向 documentElement 添加“触摸”类: 这种方法在同时支持触摸和鼠标输入的设备中也带来了挑战,因为它无法区分这两种输入。

此问题的理想解决方案是在触摸按钮后立即删除悬停状态。不幸的是,浏览器本身并不支持此功能。尝试聚焦另一个元素或手动点击另一个元素不会产生所需的结果。

完美的解决方案:

CSS 媒体查询级别 4 的实现提供了明确的解决方案这个问题的解决方案。使用以下代码:

@media (hover: hover) {
    button:hover {
        background-color: blue;
    }
}

支持真正悬停(例如,使用鼠标输入)的浏览器将仅在悬停事件真实时应用悬停样式。

对于不支持真正悬停的浏览器支持此功能,可以使用腻子填充来模拟该行为。此polyfill 使您能够使用以下CSS:

html.my-true-hover button:hover {
    background-color: blue;
}

最后,使用polyfill 的JavaScript,您可以根据设备的悬停支持动态切换“my-true-hover”类的存在。这种方法有效地复制了真实悬停检测的行为,为触摸设备上的粘性悬停效果问题提供了完美的解决方案。

以上是在支持触摸的环境中,我们如何消除按钮上的粘滞悬停效果?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
Draggin'和droppin'在反应中Draggin'和droppin'在反应中Apr 17, 2025 am 11:52 AM

React生态系统为我们提供了许多库,所有库都集中在拖放的相互作用上。我们有反应,反应,可爱dnd,

快速软件快速软件Apr 17, 2025 am 11:49 AM

最近有一些关于快速软件的完美互连的事情。

带有背景折叠的嵌套梯度带有背景折叠的嵌套梯度Apr 17, 2025 am 11:47 AM

我可以说我经常使用背景折叠。 IT Wager IT几乎从未在日常CSS工作中使用。但是在斯特凡·朱迪斯(Stefan Judis)的帖子中,我想起了它,

使用React Hooks使用requestAnimationFrame使用React Hooks使用requestAnimationFrameApr 17, 2025 am 11:46 AM

使用RequestAnimationFrame进行动画化应该很容易,但是如果您还没有彻底阅读React的文档,那么您可能会遇到一些事情

需要滚动到页面顶部吗?需要滚动到页面顶部吗?Apr 17, 2025 am 11:45 AM

向用户提供此链接的最简单方法是针对元素上的ID的链接。如此...

最好的(GraphQl)API是您编写的API最好的(GraphQl)API是您编写的APIApr 17, 2025 am 11:36 AM

听着,我不是GraphQL专家,但我确实喜欢与之合作。作为前端开发人员,它向我曝光数据的方式非常酷。它就像一个菜单

在保留边框半径的同时,扩展盒子的各种方法在保留边框半径的同时,扩展盒子的各种方法Apr 17, 2025 am 11:19 AM

我最近注意到Codepen的一个有趣的更改:在悬停在主页上的笔时,有一个矩形,圆角在后面扩展。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 个月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
1 个月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
1 个月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它们
1 个月前By尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

将Eclipse与SAP NetWeaver应用服务器集成。

SecLists

SecLists

SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

VSCode Windows 64位 下载

VSCode Windows 64位 下载

微软推出的免费、功能强大的一款IDE编辑器