CSS :hover-Eigenschaften dynamisch mit JavaScript ändern
Es ist intuitiv zu glauben, dass wir CSS :hover-Eigenschaften mit JavaScript über die bekannten Eigenschaften manipulieren können Objekt. Allerdings ist :hover eine Pseudoklasse, die Stile nur dann auf ein Element anwendet, wenn die Maus darüber fährt. Dies bedeutet, dass nicht direkt über das Eigenschaftenobjekt darauf zugegriffen werden kann.
Um :hover-Eigenschaften mit JavaScript zu manipulieren, muss man über das Eigenschaftenobjekt hinausgehen und sich an die Manipulation des Stylesheets selbst wagen. Dies kann auf verschiedene Arten erreicht werden, jede mit ihren Vor- und Nachteilen:
Direkte CSS-Änderung:
document.getElementsByTagName("style")[0].innerHTML = 'table td:hover{ background-color: #00ff00 }';
Während eine direkte Änderung schnell sein kann, überschreibt sie die vorhandenes Stylesheet, was möglicherweise zu unerwarteten Konsequenzen führt.
Erstellen eines neuen Stylesheet:
var css = 'table td:hover{ background-color: #00ff00 }'; var style = document.createElement('style'); style.type = 'text/css'; style.appendChild(document.createTextNode(css)); document.getElementsByTagName('head')[0].appendChild(style);
Diese Methode ermöglicht kontrolliertere Stiländerungen, indem ein neues Stylesheet erstellt wird, das nur die gewünschten :hover-Änderungen enthält. Es bringt jedoch auch den Aufwand mit sich, mehrere Stylesheets zu verwalten.
Anhängen einer neuen Regel an das aktuelle Stylesheet:
if (style.styleSheet) { style.styleSheet.cssText += 'table td:hover{ background-color: #00ff00 }'; } else { style.appendChild(document.createTextNode('table td:hover{ background-color: #00ff00 }')); }
Dieser Ansatz erweitert das aktuelle Stylesheet durch Anhängen eine neue :hover-Regel. Es bietet ein Gleichgewicht zwischen direkter Änderung und der Erstellung eines neuen Stylesheets.
Letztendlich hängt die gewählte Methode von der Komplexität der erforderlichen Änderungen und der gesamten Website-Architektur ab. Das dynamische Ändern von :hover-Eigenschaften mit JavaScript bietet Flexibilität beim Erstellen interaktiver Effekte.
Das obige ist der detaillierte Inhalt vonWie kann ich CSS :hover-Eigenschaften mit JavaScript dynamisch ändern?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Die CSS-Box-Shadow- und Umrisseigenschaften haben Thema gewonnen. JSON-Unterstützung in WordPress 6.1. Sei ein paar Beispiele für die Funktionsweise in realen Themen und welche Optionen wir diese Stile auf WordPress -Blöcke und Elemente anwenden müssen.

Wenn Sie kürzlich mit GraphQL gearbeitet oder seine Vor- und Nachteile überprüft haben, haben Sie zweifellos Dinge wie "GraphQL nicht unterstützen Caching" oder gehört

Die Sufelte Transition -API bietet eine Möglichkeit, Komponenten zu beleben, wenn sie das Dokument eingeben oder verlassen, einschließlich benutzerdefinierter Svelte -Übergänge.

In diesem Artikel werden wir in die Welt der Scrollbars eintauchen. Ich weiß, es klingt nicht zu glamourös, aber vertrau mir, eine gut gestaltete Seite geht Hand in Hand

Wie viel Zeit damit, die Inhaltspräsentation für Ihre Websites zu entwerfen? Wenn Sie einen neuen Blog -Beitrag schreiben oder eine neue Seite erstellen, denken Sie darüber nach

Mit dem jüngsten Aufstieg von Bitcoins Preis über 20.000 USD und kürzlich von 30.000, dachte ich, es lohnt

NPM-Befehle führen verschiedene Aufgaben für Sie aus, entweder als einmalige oder als kontinuierlich ausgeführter Vorgang für Dinge wie das Starten eines Servers oder das Kompilieren von Code.

Ich habe mich neulich mit Eric Meyer unterhalten und erinnerte mich an eine Eric Meyer -Geschichte aus meinen prägenden Jahren. Ich habe einen Blog -Beitrag über CSS -Spezifität geschrieben, und


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Herunterladen der Mac-Version des Atom-Editors
Der beliebteste Open-Source-Editor

Dreamweaver CS6
Visuelle Webentwicklungstools

Dreamweaver Mac
Visuelle Webentwicklungstools

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

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.