Heim Web-Frontend js-Tutorial Zusammenfassung der Methoden zum Ändern von CSS-Stilen in JavaScript_Javascript-Kenntnissen

Zusammenfassung der Methoden zum Ändern von CSS-Stilen in JavaScript_Javascript-Kenntnissen

May 16, 2016 pm 04:00 PM
javascript

Mit JavaScript können Sie CSS-Stile im Handumdrehen ändern, sodass Sie die Aufmerksamkeit des Benutzers auf die Stelle lenken können, auf die er sich konzentrieren soll, und ein besseres interaktives Erlebnis bieten.

Es gibt 4 Möglichkeiten, CSS mit JavaScript zu ändern:

Knotenstil ändern (Inline-Stil); Knotenklasse oder -id ändern;
Neues CSS schreiben;
Ersetzen Sie das Stylesheet auf der Seite.

Ich persönlich empfehle die Verwendung der beiden letztgenannten Methoden. Fast alle Funktionen können mit den ersten beiden Methoden erreicht werden, und der Code ist klarer und leichter zu verstehen.

Ich werde später auch darüber sprechen, wie man den tatsächlichen Stil des Elements und die Vorsichtsmaßnahmen in ein Formular bringt.

1. Knotenstil (Inline-Stil) ändern

Diese Methode hat das höchste Gewicht. Sie wird direkt auf das Stilattribut des Knotens geschrieben. Sie überschreibt den von anderen Methoden festgelegten Stil. Die Anwendung ist ganz einfach:


1

2

var element = document.getElementById("test");

element.style.display = "none" //让元素隐藏

Nach dem Login kopieren
Aber es sollte beachtet werden, dass einige CSS-Stilnamen aus mehreren Wörtern bestehen, wie z. B. Schriftgröße, Hintergrundbild usw. Sie sind alle mit Bindestrichen (-) verbunden. In JavaScript bedeuten Bindestriche jedoch „Minus“. " und kann daher nicht als Attributname verwendet werden. Wir müssen „camelCase“ verwenden, um Attributnamen wie „fontSize“ und „backgroundImage“ zu schreiben.

Beachten Sie außerdem, dass viele Stile Einheiten haben und nicht nur eine Zahl angegeben werden können. Zu den Einheiten von „fontSize“ gehören beispielsweise px, em, % (Prozentsatz) usw.

Diese Methode verstößt gegen das Prinzip der Trennung von Leistung und Verhalten. Sie eignet sich im Allgemeinen nur zum Definieren von Echtzeitstilen (in Bezug auf das Verhalten) von Elementen, die sich häufig ändern Die Attribute ändern sich beim Ziehen ständig. Mit dieser Methode können sie nicht im Handumdrehen geändert werden.

2. Klasse und ID ändern

id und class sind „Hooks“ zum Festlegen von Stilen. Nach Änderungen aktualisiert der Browser automatisch den Stil des Elements.


Die Methode zum Ändern der ID ähnelt der von class, ich persönlich empfehle jedoch nicht, sie auf diese Weise zu verwenden, da die ID zum Auffinden von Elementen verwendet wird. Es ist am besten, sie nicht zum Definieren des Anzeigestils von Elementen und der ID zu verwenden Wird häufig als JavaScript-Hook verwendet. Kann unnötige Fehler verursachen.

In JavaScript ist „class“ ein reserviertes Schlüsselwort. Verwenden Sie daher „className“ als Attribut für den Zugriff auf die Elementklasse, zum Beispiel:

1

2

3

4

5

6

7

8

.redColor{

 color: red;

}

.yellowBack{

 background: yellow;

}

element.className = "redColor";//设置class

element.className += " yellowBack";//增加class

Nach dem Login kopieren
Bedrückender ist jedoch, dass dieses Attribut eine Zeichenfolge ist, die alle Klassen des Elements enthält. Alle Klassen sind durch Leerzeichen getrennt, was das Löschen von Klassen sehr umständlich macht (fügen Sie sie einfach hinzu und stellen Sie einfach eine Zeichenfolgenverbindung zwischen ihnen her). , aber denken Sie daran, vorne ein Leerzeichen einzufügen~).

Ich habe beim Löschen reguläre Ausdrücke verwendet und die Klasse entsprechend ihren verschiedenen Positionen in der Zeichenfolge (Kopf, Ende, Mitte) gelöscht, aber dann habe ich mir eine bessere Möglichkeit überlegt, nämlich die Klasse am Anfang und am Ende zu löschen Fügen Sie jedem des className-Attributs ein Leerzeichen hinzu, und dann wird alles zur mittleren Methode und ersetzt direkt die Teilzeichenfolge:


1

2

3

4

5

6

7

//删除class

function removeClass(element,classRomove){

var classNames = " "+element.className+" ";

classNames = classNames .replace(" "+classRomove+" ", " ");

//String.trim(classNames);

element.className = classNames;

}

Nach dem Login kopieren
Am besten verwenden Sie diese Methode für allgemeine Stiländerungen. JavaScript gibt nur Anweisungen für Stiländerungen aus.

Die letzten beiden Methoden sind weder elegant noch weisen sie gewisse Kompatibilitätsprobleme auf, daher werde ich sie nicht vorstellen~

3. Holen Sie sich den echten Stil

Das erste, was klargestellt werden muss, ist, dass element.style nicht verwendet werden kann. Es können nur Inline-Stile abgerufen werden, und die Definitionen im Stylesheet können nicht abgerufen werden.

Da der Stil eines Elements an so vielen Stellen definiert werden kann, ist es schwer zu sagen, wie sein tatsächlicher Stil aussieht. Gibt es eine Möglichkeit, den tatsächlichen Stil des Elements im Browser anzuzeigen?
Tatsächlich stellen sowohl Microsoft als auch W3C entsprechende Methoden bereit. Wir müssen sie nur kapseln, um sie zu verwenden:

1

2

3

4

5

6

7

8

9

10

//获取元素样式

function getRealStyle(element,styleName){

var realStyle = null;

if(element.currentStyle){

realStyle = element.currentStyle[styleName];//IE

}else if(window.getComputedStyle){

realStyle=window.getComputedStyle(element,null)[styleName];//W3C

}

return realStyle;

}

Nach dem Login kopieren
Denken Sie daran, dass der übergebene styleName im „Camel-Case-Format“ vorliegt~~

4. Formulare anzeigen und ausblenden (CSS nicht missbrauchen)

Wir sehen häufig, dass einige Formularoptionen dynamisch hinzugefügt werden. Wenn Sie beispielsweise in einem Formular „Verheiratet“ als Familienstand auswählen, wird ein zusätzliches Eingabefeld angezeigt, in das Sie den Namen Ihres Ehepartners eingeben können.


Wenn es keine Wahl gibt, müssen Sie natürlich alle Formulare im Zusammenhang mit „Ehepartner“ ausblenden, aber Sie sollten zu diesem Zeitpunkt kein CSS verwenden, um das Problem zu lösen, d. h. Sie können style.display="none" nicht verwenden. um es zu verbergen.


Denn egal, ob Sie es ausblenden oder nicht, das Eingabefeld ist vorhanden und nimmt weder zu, noch verringert es sich Dieses Mal wird der Inhalt dieses versteckten Eingabefelds zusammen übermittelt und es können unerwartete Fehler auftreten ~


Der richtige Ansatz besteht darin, diesen Inhalt im DOM-Hyperraum zu platzieren, damit es nicht zu den oben genannten Problemen kommt.

Das Obige ist der gesamte Inhalt dieses Artikels. Ich hoffe, er gefällt Ihnen allen.

Erklärung dieser Website
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

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

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

So implementieren Sie ein Online-Spracherkennungssystem mit WebSocket und JavaScript So implementieren Sie ein Online-Spracherkennungssystem mit WebSocket und JavaScript Dec 17, 2023 pm 02:54 PM

So implementieren Sie mit WebSocket und JavaScript ein Online-Spracherkennungssystem. Einführung: Mit der kontinuierlichen Weiterentwicklung der Technologie ist die Spracherkennungstechnologie zu einem wichtigen Bestandteil des Bereichs der künstlichen Intelligenz geworden. Das auf WebSocket und JavaScript basierende Online-Spracherkennungssystem zeichnet sich durch geringe Latenz, Echtzeit und plattformübergreifende Eigenschaften aus und hat sich zu einer weit verbreiteten Lösung entwickelt. In diesem Artikel wird erläutert, wie Sie mit WebSocket und JavaScript ein Online-Spracherkennungssystem implementieren.

WebSocket und JavaScript: Schlüsseltechnologien zur Implementierung von Echtzeitüberwachungssystemen WebSocket und JavaScript: Schlüsseltechnologien zur Implementierung von Echtzeitüberwachungssystemen Dec 17, 2023 pm 05:30 PM

WebSocket und JavaScript: Schlüsseltechnologien zur Realisierung von Echtzeit-Überwachungssystemen Einführung: Mit der rasanten Entwicklung der Internet-Technologie wurden Echtzeit-Überwachungssysteme in verschiedenen Bereichen weit verbreitet eingesetzt. Eine der Schlüsseltechnologien zur Erzielung einer Echtzeitüberwachung ist die Kombination von WebSocket und JavaScript. In diesem Artikel wird die Anwendung von WebSocket und JavaScript in Echtzeitüberwachungssystemen vorgestellt, Codebeispiele gegeben und deren Implementierungsprinzipien ausführlich erläutert. 1. WebSocket-Technologie

Verwendung von JavaScript und WebSocket zur Implementierung eines Echtzeit-Online-Bestellsystems Verwendung von JavaScript und WebSocket zur Implementierung eines Echtzeit-Online-Bestellsystems Dec 17, 2023 pm 12:09 PM

Einführung in die Verwendung von JavaScript und WebSocket zur Implementierung eines Online-Bestellsystems in Echtzeit: Mit der Popularität des Internets und dem Fortschritt der Technologie haben immer mehr Restaurants damit begonnen, Online-Bestelldienste anzubieten. Um ein Echtzeit-Online-Bestellsystem zu implementieren, können wir JavaScript und WebSocket-Technologie verwenden. WebSocket ist ein Vollduplex-Kommunikationsprotokoll, das auf dem TCP-Protokoll basiert und eine bidirektionale Kommunikation zwischen Client und Server in Echtzeit realisieren kann. Im Echtzeit-Online-Bestellsystem, wenn der Benutzer Gerichte auswählt und eine Bestellung aufgibt

So implementieren Sie ein Online-Reservierungssystem mit WebSocket und JavaScript So implementieren Sie ein Online-Reservierungssystem mit WebSocket und JavaScript Dec 17, 2023 am 09:39 AM

So implementieren Sie ein Online-Reservierungssystem mit WebSocket und JavaScript. Im heutigen digitalen Zeitalter müssen immer mehr Unternehmen und Dienste Online-Reservierungsfunktionen bereitstellen. Es ist von entscheidender Bedeutung, ein effizientes Online-Reservierungssystem in Echtzeit zu implementieren. In diesem Artikel wird erläutert, wie Sie mit WebSocket und JavaScript ein Online-Reservierungssystem implementieren, und es werden spezifische Codebeispiele bereitgestellt. 1. Was ist WebSocket? WebSocket ist eine Vollduplex-Methode für eine einzelne TCP-Verbindung.

JavaScript und WebSocket: Aufbau eines effizienten Echtzeit-Wettervorhersagesystems JavaScript und WebSocket: Aufbau eines effizienten Echtzeit-Wettervorhersagesystems Dec 17, 2023 pm 05:13 PM

JavaScript und WebSocket: Aufbau eines effizienten Echtzeit-Wettervorhersagesystems Einführung: Heutzutage ist die Genauigkeit von Wettervorhersagen für das tägliche Leben und die Entscheidungsfindung von großer Bedeutung. Mit der Weiterentwicklung der Technologie können wir genauere und zuverlässigere Wettervorhersagen liefern, indem wir Wetterdaten in Echtzeit erhalten. In diesem Artikel erfahren Sie, wie Sie mit JavaScript und WebSocket-Technologie ein effizientes Echtzeit-Wettervorhersagesystem aufbauen. In diesem Artikel wird der Implementierungsprozess anhand spezifischer Codebeispiele demonstriert. Wir

Einfaches JavaScript-Tutorial: So erhalten Sie den HTTP-Statuscode Einfaches JavaScript-Tutorial: So erhalten Sie den HTTP-Statuscode Jan 05, 2024 pm 06:08 PM

JavaScript-Tutorial: So erhalten Sie HTTP-Statuscode. Es sind spezifische Codebeispiele erforderlich. Vorwort: Bei der Webentwicklung ist häufig die Dateninteraktion mit dem Server erforderlich. Bei der Kommunikation mit dem Server müssen wir häufig den zurückgegebenen HTTP-Statuscode abrufen, um festzustellen, ob der Vorgang erfolgreich ist, und die entsprechende Verarbeitung basierend auf verschiedenen Statuscodes durchführen. In diesem Artikel erfahren Sie, wie Sie mit JavaScript HTTP-Statuscodes abrufen und einige praktische Codebeispiele bereitstellen. Verwenden von XMLHttpRequest

So verwenden Sie insertBefore in Javascript So verwenden Sie insertBefore in Javascript Nov 24, 2023 am 11:56 AM

Verwendung: In JavaScript wird die Methode insertBefore() verwendet, um einen neuen Knoten in den DOM-Baum einzufügen. Diese Methode erfordert zwei Parameter: den neuen Knoten, der eingefügt werden soll, und den Referenzknoten (d. h. den Knoten, an dem der neue Knoten eingefügt wird).

JavaScript und WebSocket: Aufbau eines effizienten Echtzeit-Bildverarbeitungssystems JavaScript und WebSocket: Aufbau eines effizienten Echtzeit-Bildverarbeitungssystems Dec 17, 2023 am 08:41 AM

JavaScript ist eine in der Webentwicklung weit verbreitete Programmiersprache, während WebSocket ein Netzwerkprotokoll für die Echtzeitkommunikation ist. Durch die Kombination der leistungsstarken Funktionen beider können wir ein effizientes Echtzeit-Bildverarbeitungssystem erstellen. In diesem Artikel wird erläutert, wie dieses System mithilfe von JavaScript und WebSocket implementiert wird, und es werden spezifische Codebeispiele bereitgestellt. Zunächst müssen wir die Anforderungen und Ziele des Echtzeit-Bildverarbeitungssystems klären. Angenommen, wir haben ein Kameragerät, das Bilddaten in Echtzeit sammeln kann

See all articles