Rumah >hujung hadapan web >tutorial css >Bagaimanakah Saya Boleh Mengubah Pembolehubah CSS Secara Pengaturcaraan dengan JavaScript?

Bagaimanakah Saya Boleh Mengubah Pembolehubah CSS Secara Pengaturcaraan dengan JavaScript?

Barbara Streisand
Barbara Streisandasal
2024-12-10 18:35:14755semak imbas

How Can I Programmatically Change CSS Variables with JavaScript?

Menukar Pembolehubah CSS dengan JavaScript

Mengawal warna projek melalui pembolehubah CSS membolehkan penetapan mudah. Walau bagaimanapun, menetapkan pembolehubah ini secara pengaturcaraan boleh mencabar.

Pada mulanya, percubaan dibuat untuk mengubah suai atribut menggunakan setAttribute dan kaedah .css jQuery. Walau bagaimanapun, ini mengakibatkan ralat.

Penyelesaian:

Pembolehubah CSS boleh diedit menggunakan salah satu daripada tiga ini kaedah:

  • el.style.cssTeks:

    document.documentElement.style.cssText = "--main-background-color: red";
  • el.style. setProperty:

    document.documentElement.style.setProperty("--main-background-color", "green");
  • el.setAttribute:

    document.documentElement.setAttribute("style", "--main-background-color: green");

The kaedah terakhir ialah kaedah yang digunakan pada mulanya tetapi dengan sintaks yang salah.

Demo:

Demo ini menunjukkan pembolehubah CSS yang mentakrifkan warna latar belakang, yang diubah oleh JavaScript selepas 2 saat:

<html>
<head>
  <style>
    html {
      --main-background-image: url(../images/starsBackground.jpg);
      --main-text-color: #4CAF50;
      --main-background-color: rgba(0,0,0,.25);
      --beta-background-color: rgba(0,0,0,.85);
    }

    body {
      background-color: var(--main-background-color);
    }
  </style>
</head>
<body onload="setTimeout(function() {
    document.documentElement.style.cssText = '--main-background-color: red';
  }, 2000);">
</body>
</html>

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengubah Pembolehubah CSS Secara Pengaturcaraan dengan JavaScript?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn