


Menghuraikan CSS dalam JavaScript / jQuery
Dalam artikel ini, kami akan menyelidiki masalah menghuraikan CSS dalam JavaScript, khususnya memfokuskan pada tugas mengubah kod CSS menjadi perwakilan berasaskan objek. Kami akan meneroka batasan pelaksanaan DIY dan memperkenalkan penyelesaian yang berpotensi menggunakan CSSOM.
Pelaksanaan DIY dan Cabarannya
Coretan kod yang disediakan cuba menghuraikan CSS secara manual , peraturan pemisahan pada titik bertitik dan pendakap. Walau bagaimanapun, pendekatan ini gagal apabila menemui sifat CSS dengan koma bernoktah terbenam, seperti URL latar belakang.
Pendekatan Alternatif: Menggunakan CSSOM
Untuk mengatasi cabaran ini, kita boleh memanfaatkan Model Objek CSS terbina dalam penyemak imbas (CSSOM). CSSOM membolehkan kami mengakses dan memanipulasi peraturan CSS secara dinamik. Kami boleh menggunakan keupayaan ini untuk tujuan penghuraian.
Pelaksanaan menggunakan CSSOM
Kod JavaScript berikut menunjukkan cara menggunakan CSSOM untuk menghuraikan CSS:
var rulesForCssText = function (styleContent) { var doc = document.implementation.createHTMLDocument(""), styleElement = document.createElement("style"); styleElement.textContent = styleContent; // the style will only be parsed once it is added to a document doc.body.appendChild(styleElement); return styleElement.sheet.cssRules; };
Untuk setiap peraturan yang dikembalikan oleh rulesForCssText, kita boleh memeriksa sifatnya menggunakan rule.style.
Contoh Penggunaan
Untuk menggambarkan penggunaan pendekatan ini, pertimbangkan JavaScript Fiddle berikut (https://jsfiddle.net/v2JsZ/):
var css = "a { color: red; }"; var rules = rulesForCssText(css); console.log(rules[0].selectorText); // "a" console.log(rules[0].style.color); // "red"
Kesimpulan
Sementara penghuraian manual CSS dalam JavaScript adalah mungkin, ia memperkenalkan kemungkinan perangkap. Dengan memanfaatkan CSSOM, kami boleh memanfaatkan keupayaan penyemak imbas untuk penghuraian CSS yang boleh dipercayai dan cekap.
Atas ialah kandungan terperinci Bagaimanakah JavaScript Menghuraikan CSS Menggunakan CSSOM dengan Cekap?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Let ' s katakan kami ' bekerja di laman web laman web berita. Anda ' mungkin biasa melihat beberapa kandungan berasaskan kad dalam susun atur grid, bukan? Di sini ' s klasik

Kami merangkumi idea untuk menghidupkan teks melengkung tidak lama dahulu apabila artikel New York Times yang menyeronokkan keluar. Yang saya buat adalah mengintip bagaimana mereka melakukannya dan mengeluarkannya

Snowpack. Suka nama itu. Ini adalah perkara baru dari orang Pika, yang ada pada sesuatu. Ia ' s alternatif Bundler, dalam erti kata. Ia melebihi pakej

NetNewswire adalah salah satu aplikasi RSS klasik, debutnya pada tahun 2002. Saya cukup mencetuskan ketika ia pergi 5.0 dan dibuka pada bulan Ogos 2019! Anda boleh menggagalkannya dengan betul

Saya baru -baru ini mula melukis pada iPad saya menggunakan aplikasi ProCreate dengan Pensil Apple. Saya menikmati fleksibiliti melukis dengan cara ini. Apa yang biasanya menghalang saya

Sejak saya mula -mula berbunyi pada perkara CSS4¹, ada lebih banyak perbincangan di atasnya. Saya akan mengulangi pemikiran kegemaran saya dari orang lain di sini. Ada

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

Saya ' telah bersalah secara terbuka merungut kerumitan HTTPS. Pada masa lalu, saya membeli sijil SSL dari vendor pihak ketiga dan menghadapi masalah


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

MantisBT
Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

Dreamweaver Mac版
Alat pembangunan web visual

ZendStudio 13.5.1 Mac
Persekitaran pembangunan bersepadu PHP yang berkuasa

MinGW - GNU Minimalis untuk Windows
Projek ini dalam proses untuk dipindahkan ke osdn.net/projects/mingw, anda boleh terus mengikuti kami di sana. MinGW: Port Windows asli bagi GNU Compiler Collection (GCC), perpustakaan import yang boleh diedarkan secara bebas dan fail pengepala untuk membina aplikasi Windows asli termasuk sambungan kepada masa jalan MSVC untuk menyokong fungsi C99. Semua perisian MinGW boleh dijalankan pada platform Windows 64-bit.

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan