Heim > Web-Frontend > js-Tutorial > Wie kann ich CSS-Stile auf einer Webseite dynamisch ändern, ohne sie neu laden zu müssen?

Wie kann ich CSS-Stile auf einer Webseite dynamisch ändern, ohne sie neu laden zu müssen?

Linda Hamilton
Freigeben: 2024-10-30 10:36:03
Original
396 Leute haben es durchsucht

How can I dynamically change CSS styles on a web page without reloading?

CSS-Stile im Handumdrehen austauschen

Sie möchten den CSS-Stil einer Webseite dynamisch ändern und dabei ein Stylesheet durch ein anderes ersetzen. In Vanilla JavaScript oder jQuery können Sie dies erreichen, indem Sie alle erforderlichen Stylesheets einbinden und diese dann selektiv aktivieren oder deaktivieren.

Option 1: Toggle rel=alternate

Stylesheets einbeziehen mit „rel=alternate“ und schalten Sie ihren Status um:

<code class="html"><link rel="stylesheet"           href="main.css">
<link rel="stylesheet alternate" href="light.css" id="light" title="Light">
<link rel="stylesheet alternate" href="dark.css"  id="dark"  title="Dark"></code>
Nach dem Login kopieren
<code class="javascript">function enableStylesheet (node) {
  node.rel = 'stylesheet';
}

function disableStylesheet (node) {
  node.rel = 'alternate stylesheet';
}</code>
Nach dem Login kopieren

Option 2: Deaktivieren und umschalten

Stylesheets mit „rel=stylesheet“ einschließen und „class=alternate“ und schalten Sie deren „disabled“-Eigenschaft um:

<code class="html"><link rel="stylesheet" href="main.css">
<link rel="stylesheet" href="light.css" id="light" class="alternate">
<link rel="stylesheet" href="dark.css"  id="dark"  class="alternate"></code>
Nach dem Login kopieren
<code class="javascript">function enableStylesheet (node) {
  node.disabled = false;
}

function disableStylesheet (node) {
  node.disabled = true;
}</code>
Nach dem Login kopieren

Option 3: Toggle media=none

Stylesheets einschließen mit „ media=none“ und schalten Sie ihr „media“-Attribut um:

<code class="html"><link rel="stylesheet" href="main.css">
<link rel="stylesheet" href="light.css" media="none" id="light">
<link rel="stylesheet" href="dark.css"  media="none" id="dark"></code>
Nach dem Login kopieren
<code class="javascript">function enableStylesheet (node) {
  node.media = '';
}

function disableStylesheet (node) {
  node.media = 'none';
}</code>
Nach dem Login kopieren

Wählen Sie einen Stylesheet-Knoten mit getElementById, querySelector oder anderen Methoden aus. Verwenden Sie bei Bedarf jQuery für die weitere Verarbeitung. Mit diesem Ansatz können Sie CSS-Stile im Handumdrehen wechseln, ohne die Seite neu laden zu müssen.

Das obige ist der detaillierte Inhalt vonWie kann ich CSS-Stile auf einer Webseite dynamisch ändern, ohne sie neu laden zu müssen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage