suchen
HeimWeb-FrontendCSS-TutorialInteraktionsmedienmerkmale und ihr Potenzial (für falsche Annahmen)

Interaktionsmedienmerkmale und ihr Potenzial (für falsche Annahmen)

Dieser Artikel, ein wesentlich erweitertes Update eines 2015 Deva-Stücks, verdeutlicht falsche Vorstellungen im Zusammenhang mit Medienabfragen Level 4 Interaction Media-Funktionen ( pointer , hover , any-pointer , any-hover ). Der ursprüngliche Artikel hat any-hover: none ; Diese Version entspricht dem neuesten Arbeitsentwurf und befasst sich mit Inkonsistenzen über Browser -Implementierungen (siehe aktuelle Testergebnisse und verwandte Fehlerberichte).

Medienabfragen Level 4 zielt darauf ab, das Website -Styling und -funktionalität (CSS -Interaktivität oder JavaScript -Verhalten über window.matchMedia ) basierend auf Benutzereingabegeräten anzupassen. Obwohl im Allgemeinen gut unterstützt, bleiben die Implementierungsschwankungen bestehen.

Bei gemeinsamen Anwendungsfällen wird die Anpassung der Kontrollgrößen basierend auf Touchscreen im Vergleich zu Maus-/Stiftgebrauch oder zur konditionellen Aktivierung von schwebebasierten Menüs:

 <code>@media (pointer: fine) { /* Mouse or stylus: small controls okay */ } @media (pointer: coarse) { /* Touchscreen: larger touch targets */ } @media (hover: hover) { /* Enable hover menus */ } @media (hover: none) { /* Disable hover menus */ }</code>

Entwickler nutzen diese Funktionen häufig für die Erkennung von Berührungen und hören normalerweise nach Berührungsereignissen, wenn pointer: coarse wird festgestellt:

 if (window.matchmedia && window.matchmedia ("(Zeiger: grob)"). Übereinstimmung) {
 / * Grobzeiger: Hören Sie sich an Touch -Ereignisse */
 target.addeventListener ("TouchStart", ...);
} anders {
 / * Ansonsten verwenden Sie Maus-/Tastaturereignisse */
}

Dieser Ansatz ist jedoch simpel und versteht den Zweck der Merkmale.

Primäre Eingangsbeschränkungen

pointer und hover zeigen nur die Eigenschaften des primären Zeigereingangs. Dies kann von der tatsächlichen primären Eingabe des Benutzers abweichen, insbesondere mit verschwommenem Gerät/Eingangsleitungen. Entscheidend ist, dass diese Funktionen keine Benutzer nur für Tastaturen erkennen. Stellen Sie daher unabhängig von Abfrageergebnissen die Tastatur -Zugänglichkeit sicher.

Ein Telefon mit einer Bluetooth -Maus kann pointer: coarse und hover: none , obwohl der Benutzer hauptsächlich die Maus verwendet. Umgekehrt kann ein Oberflächen -Tablet hauptsächlich das Trackpad ( pointer: fine ) verwenden, aber der Benutzer bevorzugt den Touchscreen.

Dieses Problem wird von any-pointer und any-hover angesprochen.

Bewertung aller Eingaben

any-pointer und any-hover spiegeln die kombinierten Funktionen aller Zeigereingänge wider. Mehrere Werte können übereinstimmen, wenn Eingaben unterschiedliche Eigenschaften aufweisen. Aktuelle Implementierungen verhalten sich im Allgemeinen wie folgt:

Um die ursprünglichen Anwendungsfälle zu verbessern, sind Grundentscheidungen für alle Zeigereingaben: "Wenn eine Eingabe grob ist, vergrößern Sie die Steuerelemente" und "Schwebemenüs aktivieren, wenn mindestens ein Eingang den Schwebedruck unterstützt".

 <code>@media (any-pointer: coarse) { /* At least one coarse pointer: larger controls */ } @media (any-hover: hover) { /* At least one hover-capable input: enable hover menus */ }</code>

any-pointer: none ist nur dann wahr, wenn keine Zeigereingänge vorhanden sind. any-hover: none ist nur dann wahr, wenn keiner der Eingänge den Schweber unterstützt, was es weitgehend überflüssig macht.

Kombination von Anfragen zur Nuance

Kombinieren Sie Abfragen für raffinierte Bewertungen:

 <code>@media (pointer: coarse) and (any-pointer: fine) { /* Primary input is touchscreen, but a fine input exists. Prioritize touch, but mouse/stylus users can still interact. */ } @media (pointer: fine) and (any-pointer: coarse) { /* Primary input is mouse/stylus, but a touchscreen exists. Larger controls might be safest. */ } @media (hover: none) and (any-hover: hover) { /* Primary input lacks hover, but another input supports it. Treat hover as optional. */ }</code>

Browser bewerten dynamisch Abfragen als Reaktion auf Umweltveränderungen (z. B. Hinzufügen einer Bluetooth-Maus).

Scripting kann notwendig sein

Interaktionsmedienfunktionen geben den aktuell verwendeten Eingang nicht an. Tools wie welche Eingabe? Verfolgen Sie JavaScript -Ereignisse, aber dies liefert nur Informationen nach Beginn der Interaktion und kann aufgrund von gefälschten Ereignissen (Assistive Technologies, iOS -Volltastaturunterstützung) ungenau sein.

Vermeiden Sie gebrochene Erfahrungen

Ereignisbasierte Toucherkennung ( pointer: coarse -> Hören Sie sich Touch -Events an) ist fehlerhaft. Es verhindert die Verwendung von Nicht-Touchscreen-Eingängen auf Touch-Geräten und Touchscreen-Eingängen auf hauptsächlich mausgesteuerten Geräten. Hören Sie stattdessen immer auf Maus-/Tastaturereignisse an und fügen Sie Touch Event-Hörer nur dann hinzu, wenn any-pointer: coarse ist wahr:

 / * Hören Sie immer Maus/Tastaturereignisse *///
target.addeventListener ("klicken", ...);

if (window.matchmedia && window.matchmedia ("(Any-Zeiger: grob)"). Übereinstimmung) {
 / * Wenn ein grober Zeiger existiert, hören Sie auch nach Touch -Events */////
 target.addeventListener ("TouchStart", ...);
}

Verwenden Sie alternativ Zeigerereignisse für ein einheitliches Eingangsumschlag.

Explizite Benutzerauswahl

Geben Sie einen vom Benutzer ausgewählten Modus (Touch/Maus) an, um Fallstricke in Eingangserkennung zu vermeiden. Verwenden Sie Medienabfragen, um die Standardeinstellung zu informieren, und erkennen Sie die Berührungseingabe, um einen Modusschalter fordern.

Verantwortungsbewusste Abfrage

Verstehen Sie die Grenzen der Interaktionsmedienfunktionen. Nehmen Sie nicht einen einzelnen Eingangstyp an, verlassen Sie sich ausschließlich auf pointer und hover oder vernachlässigen Sie die Zugänglichkeit der Tastatur. Priorisieren Sie stattdessen Touchfriendess, bieten Sie die Auswahl der Benutzer und gewährleisten Sie immer die Tastatur-Zugänglichkeit.

Das obige ist der detaillierte Inhalt vonInteraktionsmedienmerkmale und ihr Potenzial (für falsche Annahmen). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Wie viel Spezifität haben @Rules wie @Keyframes und @Media?Wie viel Spezifität haben @Rules wie @Keyframes und @Media?Apr 18, 2025 am 11:34 AM

Ich habe diese Frage neulich bekommen. Mein erster Gedanke ist: seltsame Frage! Bei der Spezifität geht es um Selektoren, und Rules sind keine Selektoren, also ... irrelevant?

Können Sie @Media und @Support -Abfragen nisten?Können Sie @Media und @Support -Abfragen nisten?Apr 18, 2025 am 11:32 AM

Ja, Sie können, und es ist nicht wirklich wichtig in welcher Reihenfolge. Ein CSS -Präprozessor ist nicht erforderlich. Es funktioniert in regulären CSS.

Schnellschluck -Cache -BustingSchnellschluck -Cache -BustingApr 18, 2025 am 11:23 AM

Sie sollten auf jeden Fall weitausgestellte Cache-Header auf Ihren Vermögenswerten wie CSS und JavaScript (und Bilder und Schriftarten und was auch immer) festlegen. Das sagt dem Browser

Auf der Suche nach einem Stapel, der die Qualität und Komplexität von CSS überwachtAuf der Suche nach einem Stapel, der die Qualität und Komplexität von CSS überwachtApr 18, 2025 am 11:22 AM

Viele Entwickler schreiben darüber, wie sie eine CSS -Codebasis pflegen können, aber nicht viele von ihnen schreiben darüber, wie sie die Qualität dieser Codebasis messen. Sicher, wir haben

Datalist dient dazu, Werte vorzuschlagen, ohne Werte durchzusetzenDatalist dient dazu, Werte vorzuschlagen, ohne Werte durchzusetzenApr 18, 2025 am 11:08 AM

Haben Sie jemals ein Formular gehabt, das ein kurzes, willkürliches Stück Text akzeptieren musste? Wie ein Name oder was auch immer. Das ist genau das, wofür es ist. Es gibt viele

Frontkonferenz in ZürichFrontkonferenz in ZürichApr 18, 2025 am 11:03 AM

Ich bin so aufgeregt, nach Zürich, der Schweiz, zur Frontkonferenz zu gehen (liebe diesen Namen und diese URL!). Ich war noch nie in der Schweiz, also bin ich aufgeregt

Erstellen einer serverlosen Full-Stack-Anwendung mit Cloudflare-MitarbeiternErstellen einer serverlosen Full-Stack-Anwendung mit Cloudflare-MitarbeiternApr 18, 2025 am 10:58 AM

Eine meiner Lieblingsentwicklungen in der Softwareentwicklung war das Aufkommen von Serverless. Als Entwickler, der die Tendenz hat, sich in den Details festzuhalten

Erstellen dynamischer Routen in einer Nuxt -AnwendungErstellen dynamischer Routen in einer Nuxt -AnwendungApr 18, 2025 am 10:53 AM

In diesem Beitrag werden wir eine E -Commerce -Store -Demo verwenden, die ich für Netlify erstellt und bereitgestellt habe, um zu zeigen, wie wir dynamische Routen für eingehende Daten erstellen können. Es ist fair

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Crossplay haben?
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

MinGW – Minimalistisches GNU für Windows

MinGW – Minimalistisches GNU für Windows

Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ist eine PHP/MySQL-Webanwendung, die sehr anfällig ist. Seine Hauptziele bestehen darin, Sicherheitsexperten dabei zu helfen, ihre Fähigkeiten und Tools in einem rechtlichen Umfeld zu testen, Webentwicklern dabei zu helfen, den Prozess der Sicherung von Webanwendungen besser zu verstehen, und Lehrern/Schülern dabei zu helfen, in einer Unterrichtsumgebung Webanwendungen zu lehren/lernen Sicherheit. Das Ziel von DVWA besteht darin, einige der häufigsten Web-Schwachstellen über eine einfache und unkomplizierte Benutzeroberfläche mit unterschiedlichen Schwierigkeitsgraden zu üben. Bitte beachten Sie, dass diese Software

SecLists

SecLists

SecLists ist der ultimative Begleiter für Sicherheitstester. Dabei handelt es sich um eine Sammlung verschiedener Arten von Listen, die häufig bei Sicherheitsbewertungen verwendet werden, an einem Ort. SecLists trägt dazu bei, Sicherheitstests effizienter und produktiver zu gestalten, indem es bequem alle Listen bereitstellt, die ein Sicherheitstester benötigen könnte. Zu den Listentypen gehören Benutzernamen, Passwörter, URLs, Fuzzing-Payloads, Muster für vertrauliche Daten, Web-Shells und mehr. Der Tester kann dieses Repository einfach auf einen neuen Testcomputer übertragen und hat dann Zugriff auf alle Arten von Listen, die er benötigt.

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor