Rumah hujung hadapan web tutorial css Bagaimanakah Saya Boleh Tukar Secara Dinamik CSS :hover Properties dengan JavaScript?

Bagaimanakah Saya Boleh Tukar Secara Dinamik CSS :hover Properties dengan JavaScript?

Dec 11, 2024 am 04:09 AM

How Can I Dynamically Change CSS :hover Properties with JavaScript?

Tukar CSS :hover Properties Secara Dinamik dengan JavaScript

Adalah intuitif untuk berfikir kita boleh memanipulasi sifat CSS :hover dengan JavaScript melalui sifat biasa objek. Walau bagaimanapun, :hover ialah kelas pseudo yang menggunakan gaya pada elemen hanya apabila tetikus melayang di atasnya. Ini bermakna ia tidak boleh diakses secara langsung melalui objek sifat.

Untuk memanipulasi sifat :hover dengan JavaScript, seseorang mesti melangkaui objek sifat dan berusaha untuk memanipulasi lembaran gaya itu sendiri. Ini boleh dicapai dalam beberapa cara, masing-masing dengan kebaikan dan keburukannya:

Pengubahsuaian CSS Langsung:

document.getElementsByTagName("style")[0].innerHTML = 'table td:hover{ background-color: #00ff00 }';
Salin selepas log masuk

Walaupun pengubahsuaian langsung boleh dilakukan dengan pantas, ia menimpa lembaran gaya sedia ada, yang berpotensi membawa kepada akibat yang tidak dijangka.

Mencipta yang Baharu Lembaran gaya:

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);
Salin selepas log masuk

Kaedah ini membenarkan perubahan penggayaan yang lebih terkawal dengan mencipta helaian gaya baharu yang hanya menyertakan pengubahsuaian :hover yang dikehendaki. Walau bagaimanapun, ia juga membawa overhed untuk mengekalkan berbilang lembaran gaya.

Melampirkan Peraturan Baharu pada Lembaran Gaya Semasa:

if (style.styleSheet) {
    style.styleSheet.cssText += 'table td:hover{ background-color: #00ff00 }';
} else {
    style.appendChild(document.createTextNode('table td:hover{ background-color: #00ff00 }'));
}
Salin selepas log masuk

Pendekatan ini memanjangkan lembaran gaya semasa dengan menambahkan peraturan baru :hover. Ia menawarkan keseimbangan antara pengubahsuaian langsung dan mencipta helaian gaya baharu.

Akhirnya, kaedah yang dipilih bergantung pada kerumitan perubahan yang diperlukan dan keseluruhan seni bina tapak web. Mengubah suai sifat :hover secara dinamik dengan JavaScript memberikan fleksibiliti dalam mencipta kesan interaktif.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Tukar Secara Dinamik CSS :hover Properties dengan JavaScript?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Tutorial Java
1664
14
Tutorial PHP
1268
29
Tutorial C#
1248
24
Cara membuat pemasa undur animasi dengan HTML, CSS dan JavaScript Cara membuat pemasa undur animasi dengan HTML, CSS dan JavaScript Apr 11, 2025 am 11:29 AM

Pernahkah anda memerlukan pemasa undur dalam projek? Untuk sesuatu seperti itu, mungkin semula jadi untuk mencapai plugin, tetapi sebenarnya lebih banyak lagi

Panduan Atribut Data HTML Panduan Atribut Data HTML Apr 11, 2025 am 11:50 AM

Semua yang anda ingin tahu mengenai atribut data dalam HTML, CSS, dan JavaScript.

Bukti konsep untuk menjadikan sass lebih cepat Bukti konsep untuk menjadikan sass lebih cepat Apr 16, 2025 am 10:38 AM

Pada permulaan projek baru, kompilasi SASS berlaku dalam sekejap mata. Ini terasa hebat, terutamanya apabila ia dipasangkan dengan BrowserSync, yang dimuat semula

Walaupun anda tidak kelihatan, kecerunan CSS menjadi lebih baik Walaupun anda tidak kelihatan, kecerunan CSS menjadi lebih baik Apr 11, 2025 am 09:16 AM

Satu perkara yang menarik perhatian saya pada senarai ciri-ciri untuk Lea Verou ' s conic-gradient () polyfill adalah item terakhir:

Cara Membina Komponen Vue dalam Tema WordPress Cara Membina Komponen Vue dalam Tema WordPress Apr 11, 2025 am 11:03 AM

Arahan template inline membolehkan kita membina komponen Vue yang kaya sebagai peningkatan progresif ke atas markup WordPress yang sedia ada.

Perbandingan pembekal bentuk statik Perbandingan pembekal bentuk statik Apr 16, 2025 am 11:20 AM

Mari kita cuba menyusun istilah di sini: "Penyedia Borang Statik." Anda membawa html anda

PHP adalah A-OK untuk templat PHP adalah A-OK untuk templat Apr 11, 2025 am 11:04 AM

Templat PHP sering mendapat rap buruk untuk memudahkan kod subpar - tetapi itu tidak perlu berlaku. Mari kita lihat bagaimana projek PHP dapat menguatkuasakan asas

Tiga jenis kod Tiga jenis kod Apr 11, 2025 pm 12:02 PM

Setiap kali saya memulakan projek baru, saya menyusun kod yang saya cari dalam tiga jenis, atau kategori jika anda suka. Dan saya fikir jenis ini boleh digunakan

See all articles