


Preventing Sticky Hover Effects for Buttons on Touch Devices
The persistent hover state on buttons in touch devices can be a nuisance. To address this, various solutions have been proposed, but none seem fully satisfactory. One approach involves adding a "no-hover" class on touch end, but this negatively impacts performance and doesn't account for hybrid devices. Another option is to add a "touch" class to the document, but this too fails on devices with both touch and mouse capabilities.
The Ideal Solution: CSS Media Queries Level 4
With the advent of CSS Media Queries Level 4, a more refined solution has emerged:
@media (hover: hover) { button:hover { background-color: blue; } }
This media query specifically targets browsers with true/non-emulated hover support (e.g., devices with mouse-like input mechanisms). Buttons in such browsers will display the blue hover effect.
Polyfill for Legacy Browsers
For browsers without this feature, there's a JavaScript polyfill that can simulate true hover support:
html.my-true-hover button:hover { background-color: blue; }
The polyfill detects hovering capabilities and toggles the "my-true-hover" class accordingly:
$(document).on('mq4hsChange', function (e) { $(document.documentElement).toggleClass('my-true-hover', e.trueHover); });
This combination of CSS and JavaScript ensures that hover effects work flawlessly on both modern and legacy touch devices.
The above is the detailed content of How Can We Eliminate Sticky Hover Effects on Buttons for Touch Devices?. For more information, please follow other related articles on the PHP Chinese website!

Here's a container with some child elements:

Flyout menus! The second you need to implement a menu that uses a hover event to display more menu items, you're in tricky territory. For one, they should

"The power of the Web is in its universality. Access by everyone regardless of disability is an essential aspect."- Tim Berners-Lee

In this week's roundup: datepickers are giving keyboard users headaches, a new web component compiler that helps fight FOUC, we finally get our hands on styling list item markers, and four steps to getting webmentions on your site.

The short answer: flex-shrink and flex-basis are probably what you’re lookin’ for.

In this week's look around the world of web platform news, Google Search Console makes it easier to view crawled markup, we learn that custom properties

The IndieWeb is a thing! They've got a conference coming up and everything. The New Yorker is even writing about it:


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool

Zend Studio 13.0.1
Powerful PHP integrated development environment

WebStorm Mac version
Useful JavaScript development tools

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.