Properti Show
Tanda hubung otomatis dan lunak ditampilkan sesuai dengan nilai karakter tanda hubung yang ditentukan Nilai menetapkan string untuk digunakan sebagai pengganti tanda hubung, atau menunjukkan bahwa agen pengguna harus memilih string yang sesuai berdasarkan konvensi tipografi saat ini (default)
auto Agen pengguna memilih string yang sesuai berdasarkan konvensi tipografi bahasa konten. Ini adalah nilai properti default, dan hanya perlu diatur secara eksplisit untuk menimpa nilai warisan yang berbeda Nilai awal hyphenate-character =_ Contoh ini menunjukkan dua blok teks identik yang memiliki hyphenate-character =0). Blok pertama memiliki nilai tanda hubung yang diubah menjadi simbol sama dengan (" hyphenate-character =1"). Blok kedua tidak memiliki kumpulan karakter tanda hubung, yang setara dengan hyphenate-character =2 untuk agen pengguna yang mendukung properti ini Karakter yang dicadangkan dalam HTML harus diganti dengan entitas karakter Beberapa karakter dicadangkan dalam HTML If you use the less than (<) or greater than (>) signs in your text, the browser might mix them with tags. Entitas karakter digunakan untuk menampilkan karakter yang dicadangkan dalam HTML Entitas karakter terlihat seperti ini &nama kesatuan; ATAU entity_number;Untuk menampilkan tanda kurang dari (<) kita harus menulis. < atau < Keuntungan menggunakan nama entitas. Nama entitas mudah diingat Ruang Tanpa PemutusanEntitas yang umum digunakan dalam HTML adalah non-breaking space. Ruang tanpa putus adalah ruang yang tidak akan pecah menjadi baris baru Dua kata yang dipisahkan oleh spasi yang tidak putus akan tetap bersatu (tidak pecah menjadi baris baru). Ini berguna saat melanggar kata-kata mungkin mengganggu Contoh Penggunaan umum lainnya dari non-breaking space adalah untuk mencegah browser memotong spasi di halaman HTML Jika Anda menulis 10 spasi di teks Anda, browser akan menghapus 9 spasi. Untuk menambahkan spasi nyata ke teks, Anda dapat menggunakan entitas karakter Tip. Tanda hubung tidak terputus (‑) digunakan untuk menentukan karakter tanda hubung (‑) yang tidak putus menjadi baris baru Beberapa Entitas Karakter HTML yang BergunaCatatan. Nama entitas peka huruf besar-kecil Menggabungkan Tanda DiakritikTanda diakritik adalah "mesin terbang" yang ditambahkan ke sebuah surat Beberapa tanda diakritik, seperti kuburan ( ̀) dan akut ( ́) disebut aksen Tanda diakritik dapat muncul di atas dan di bawah huruf, di dalam huruf, dan di antara dua huruf Tanda diakritik dapat digunakan dalam kombinasi dengan karakter alfanumerik untuk menghasilkan karakter yang tidak ada dalam rangkaian karakter (pengkodean) yang digunakan di halaman Saat menulis CSS untuk markup dengan nilai atribut 2 atau 3 yang aneh, Anda perlu beberapa. Misalnya, Anda tidak bisa hanya menggunakan 4 untuk menargetkan elemen dengan 5. Sebagai gantinya, Anda harus melarikan diri dari karakter aneh (dalam hal ini, yang kedua 6). Melakukan hal itu akan membatalkan arti karakter CSS khusus dalam pengidentifikasi dan memungkinkan Anda merujuk ke karakter yang tidak dapat Anda ketik dengan mudah, seperti simbol Unicode gilaAda beberapa kasus lain di mana Anda mungkin ingin atau perlu keluar dari karakter di CSS. Anda bisa menulis pemilih untuk funky 3, 2, atribut atau nilai atribut, misalnya; Pengidentifikasi dan string dalam CSSPembaruan @ Maret 2022. agar lebih selaras dengan HTML. Sisa dari bagian ini dipertahankan di sini karena alasan historis, dan menjelaskan spek lama — bukan spek terbaru mendefinisikan pengidentifikasi menggunakan diagram token. Mereka mungkin berisi simbol dari _0 sampai 1, dari 2 sampai 3, dari 4 sampai 5, garis bawah ( 6), tanda hubung 7, non-ASCII simbol atau escape sequence. Mereka tidak boleh dimulai dengan angka, atau tanda hubung ( 7) diikuti dengan angka. Pengidentifikasi memerlukan setidaknya satu simbol (mis. e. string kosong bukan pengenal yang valid)Tata bahasa untuk pengidentifikasi digunakan untuk berbagai hal di seluruh spesifikasi, termasuk nama elemen, nama kelas, dan ID di pemilih Definisi spesifikasi untuk mengatakan bahwa string dapat ditulis dengan tanda kutip ganda atau dengan tanda kutip tunggal. Tanda kutip ganda tidak dapat terjadi di dalam tanda kutip ganda, kecuali lolos (mis. g. , sebagai _9 atau sebagai 0). Hal yang sama berlaku untuk tanda kutip tunggal (mis. g. , 1 atau 2). Sebuah string tidak dapat secara langsung berisi baris baru. Untuk menyertakan baris baru dalam string, gunakan urutan escape yang mewakili karakter umpan baris (U+000A), seperti 3 atau 4. Baris baru juga dapat direpresentasikan sebagai 5 (CRLF), 6 (i. e. 7 dalam bahasa lain), atau 8 (i. e. _9 dalam bahasa lain). Dimungkinkan untuk memutuskan string pada beberapa baris, untuk estetika atau alasan lain, tetapi dalam kasus seperti itu, baris baru itu sendiri harus di-escape dengan garis miring terbalik ( 0)Seperti yang Anda lihat, pelolosan karakter diperbolehkan di pengidentifikasi dan string. Jadi, mari kita cari tahu bagaimana urutan pelarian ini bekerja Bagaimana cara menghindari karakter apa pun di CSSBerikut adalah daftar aturan sederhana yang harus Anda ingat saat keluar dari karakter di CSS. Perlu diingat bahwa jika Anda menulis pemilih untuk nama kelas atau ID tertentu, sintaks ketat untuk pengidentifikasi berlaku. Jika Anda menggunakan string (dikutip) di CSS, Anda hanya perlu menghindari tanda kutip atau karakter baris baru Angka terdepanJika karakter pertama pengidentifikasi adalah numerik, Anda harus menghindarinya berdasarkan poin kode Unicode-nya. Misalnya, titik kode untuk karakter _1 adalah 2, jadi Anda akan menghindarinya sebagai 3 atau 4Pada dasarnya, untuk menghindari karakter numerik apa pun, awali saja dengan 5 dan tambahkan karakter spasi (). Yay UnicodeKarakter khusus dalam CSSKarakter apa pun yang bukan digit heksadesimal, pengumpanan baris, pengembalian kereta, atau pengumpanan formulir dapat diloloskan dengan garis miring terbalik untuk menghilangkan makna khususnya Karakter berikut memiliki arti khusus dalam CSS. 6, 7, 6, 9, 0, 1, 2, 3, 4, 5, 6, 7, 7, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 0, 0, Ada dua opsi jika Anda ingin menggunakannya. Baik Anda menggunakan titik kode Unicode — misalnya, tanda plus ( 6) adalah U+002B, jadi jika Anda ingin menggunakannya dalam pemilih CSS, Anda akan mengubahnya menjadi 8 (perhatikan karakter spasi di bagian akhir) Pilihan kedua jauh lebih elegan. lepas saja karakter menggunakan garis miring terbalik ( 0), e. g. 6 akan melarikan diri ke 2Secara teoritis, karakter _1 dapat di-escape sebagai 4, tetapi IE < 8 tidak mengenali urutan escape tersebut dengan benar. Solusinya adalah dengan menggunakan 5 sebagai gantinyaKarakter spasi putihSpasi kosong — bahkan beberapa karakter yang secara teknis tidak valid dalam nilai atribut HTML — juga dapat di-escape Karakter apa pun yang cocok dengan 6 harus di-escape berdasarkan poin kode Unicode mereka. Karakter spasi () dapat berupa garis miring terbalik (________33 _____ 0). Karakter spasi lainnya tidak perlu di-escapeGaris bawahCSS tidak mengharuskan Anda untuk keluar dari garis bawah ( 6) tetapi jika itu muncul di awal pengidentifikasi, saya sarankan tetap melakukannya untuk mencegah IE6 mengabaikan aturan sama sekaliKarakter Unicode lainnyaSelain itu, karakter yang tidak mungkin menyampaikan makna apa pun dalam CSS (mis. g. _9) dapat dan harus digunakan tanpa melarikan diriSecara teori (sesuai spesifikasi), karakter apa pun dapat diloloskan berdasarkan titik kode Unicode seperti yang dijelaskan di atas (mis. g. untuk _0, simbol "tetragram untuk pusat" U+1D306. 1 atau 2), tetapi browser WebKit lama tidak mendukung sintaks ini untuk karakter di luar BMP (diperbaiki pada April 2012)Karena bug browser, ada cara lain (non-standar) untuk keluar dari karakter ini, yaitu dengan memecahnya menjadi unit kode UTF-16 (mis. g. _3), tetapi sintaks ini (seharusnya) tidak didukung di Gecko dan Opera 12Karena saat ini tidak ada cara untuk melarikan diri dengan gaya lintas-browser tanpa merusak kompatibilitas dengan browser lama, yang terbaik adalah menggunakan karakter ini tanpa melarikan diri. Membuntuti spasi putih setelah urutan pelarian heksadesimalSetiap karakter spasi U+0020 yang segera mengikuti urutan pelolosan heksadesimal secara otomatis. Misalnya, untuk menghindari teks _4, Anda harus menggunakan 5, dengan dua karakter spasi setelah 6. Karakter ruang pertama ditelan; Karakter spasi yang mengikuti urutan escape heksadesimal hanya dapat dihilangkan jika karakter berikutnya bukan karakter spasi lain dan bukan digit heksadesimal. Misalnya, _7 menjadi 8, tetapi 9 dapat ditulis sebagai 00ContohBerikut adalah beberapa contoh acak yang menggambarkan hal ini
Untuk selengkapnya, lihat halaman demo untuk postingan blog di 01 dan 02 di HTML5…dan bagaimana dengan JavaScript?Dalam JavaScript, itu tergantung 03 dan fungsi serupa seperti 04 hanya dapat menggunakan nilai atribut yang tidak lolos, cara yang digunakan dalam HTML. Tentu saja, Anda harus mengutip apa pun sehingga Anda tetap mendapatkan string JavaScript yang validDi sisi lain, jika Anda menggunakan pemilih ini dengan Selectors API (mis. e. 05 dan 06) atau perpustakaan yang mengandalkan sintaks yang sama (e. g. jQuery/Sizzle), Anda harus mengambil dan menghindarinya lagi. Yang harus Anda lakukan hanyalah menggandakan setiap garis miring terbalik di pemilih CSS (dan tentu saja menghindari tanda kutip, jika perlu)
CSS lolos alatMengingat semua aturan ini memang terdengar menyenangkan, tetapi untuk membuat hidup sedikit lebih mudah, saya membuat alat CSS escaper sederhana yang melakukan semua kerja keras untuk Anda Cukup masukkan nilai dan itu akan memberi tahu Anda cara menghindarinya di CSS dan JavaScript, berdasarkan aturan di atas. Ini menggunakan atribut 3 dalam contohnya, tetapi tentu saja Anda dapat menggunakan string yang lolos yang sama untuk nilai atribut 2 atau properti 9. MenikmatiPerlu menghindari teks untuk digunakan dalam string atau pengidentifikasi CSS? . Saksikan berikut ini Memperbarui. Spesifikasi Model Objek CSS sekarang mendefinisikan , metode utilitas yang melakukan pelolosan untuk Anda. Saya telah menulis polyfill untuk itu Catatan. Jika Anda suka membaca tentang pelolosan CSS, mengapa tidak membaca urutan pelolosan karakter JavaScript atau referensi karakter dalam HTML? Tentang sayaHai, yang di sana. Saya Mathias. Saya bekerja di Chrome DevTools dan mesin JavaScript V8 di Google. HTML, CSS, JavaScript, Unicode, performa, dan keamanan membuat saya bersemangat. Ikuti saya di Twitter, Mastodon, dan GitHub seutje menulis. Saya sudah mengalami mimpi buruk ini karena seseorang menggunakan garis bawah di nama kelasnya dan tidak menghindarinya di CSS, yang menyebabkan IE6 mengabaikannya sepenuhnya, sementara semua browser lain dengan senang hati menerimanya tanpa melarikan diri. http. // jsbin. com/esofe3 IE6 akan menampilkan semua hijau, semua browser lain akan menampilkan semua merah Sunting. Sebenarnya, hanya 11 yang tidak lolos yang menjadi masalah, bukan 12 atau 13. Ini kasus uji yang lebih baik. http. // jsbin. com/unogus Tangkapan bagus, Nicolas GallagherSteve terus menulis. Seperti halnya saya menghargai konsep artikel ini, saya perlu mengklarifikasi sesuatu Menetapkan ID elemen untuk memulai dengan karakter angka "1,2,3,4,5,6,7,8,9,0" tidak valid. Jangan pernah melakukannya. Menggunakan string pelarian di atas untuk mengatasinya adalah peretasan, dan akan membawa Anda ke perairan yang dalam dengan cepat Lebih penting lagi, ada BEBERAPA skenario yang diambil hati oleh Microsoft dari aturan spesifikasi ini dan JavaScript AKAN GAGAL jika Anda mencoba dan mengakses elemen yang tidak dibuat dengan pengidentifikasi ID yang valid Saya akan SANGAT, SANGAT merekomendasikan penggunaan pengenal standar untuk semua ID… Mulai ID dengan karakter alfa “biasa”, atau garis bawah, dan gunakan karakter alfa, numerik, garis bawah, atau tanda hubung untuk sisa pengenal Saya tidak melihat alasan yang masuk akal mengapa seseorang perlu membuat ID dalam format selain seperti yang dijelaskan di atas… Dan jika seseorang memutuskan untuk menyulap granat tangan, jangan kaget ketika semuanya meledak
Mathias terus menulis.
Anda mungkin ingin membaca Atribut _3 mendapat lebih banyak 2y di HTML5. Bocoran. itu tidak valid di HTML4, tetapi selalu berfungsi di browser, dan HTML5 sekarang juga memungkinkan
Ingin memberikan contoh di mana ID "tidak valid" seperti itu akan menyebabkan masalah? Steve terus menulis. Yup, jadi karena IE memiliki masalah historis dengan ID, saya tidak akan pernah mencoba dan menggunakan sesuatu yang mewah, tapi ini dia Jadi IE memiliki beberapa bug dan salah satu yang terbesar adalah menggabungkan ruang nama atribut ID dan NAME… Bahkan hingga panggilan IE8 16 akan benar-benar mengembalikan elemen dengan atribut 17 yang cocok meskipun memiliki 3 yang berbeda (atau bahkan tanpa ID)Karena namespace yang "kabur" ini, dan upaya IE untuk "menebak" maksud pengembang, ada beberapa konsekuensi besar Ambil contoh formulir yang di antara bidang lainnya, berisi daftar "item" yang cocok dengan catatan dari database yang ada di formulir sebagai sekelompok bidang tersembunyi dengan 19s dan 20s yang menggunakan "kunci" dalam database
Jika Anda mencoba mengakses elemen ini dengan mengatakan, gunakan koleksi elemen FormElement seperti itu
Kode ini sepertinya akan berfungsi, tetapi tidak di IE… Masalahnya adalah ketika IE mengulangi kumpulan elemen dari formulir, kode ini diteruskan dalam “kunci”… kunci itu bisa berupa 20 elemen Ketika IE mendapatkan string yang kami berikan dengan 20 elemen, IE tidak tahu yang mana (juga browser apa pun), tetapi IE memutuskan bahwa ia akan memeriksa untuk melihat apakah nilai yang diteruskan di parse ke bilangan bulat terlebih dahulu ( . e. sebuah indeks). Kemudian jika gagal, coba sebagai 17. Cacat mendasar ini berarti jika atribut _20 Anda (atau 19 karena bug namespace) dimulai dengan angka (yang bertentangan dengan spesifikasi) saat diurai sebagai bilangan bulat… mengembalikan 26 yang kemudian dikatakan IE pada dirinya sendiri, “oh, saya punya Solusinya tentu saja sederhana… Cukup ikuti spesifikasi aslinya, dan beri nama elemen 28Ada beberapa masalah lagi… tetapi setelah melakukan pengembangan aplikasi web selama 12+ tahun, saya segera belajar untuk TIDAK menggunakan ID atau NAMA yang dimulai dengan angka. Itu akan gagal… hanya masalah waktu saja P. S. Pada satu titik saya membahas bug di atas dengan Chris Wilson (mantan Kepala Arsitek IE) dan diarahkan ke spesifikasi. Pada dasarnya itu adalah "ya ini buggy di IE, tetapi menggunakan 19s atau 20s yang memulai numerik bertentangan dengan spesifikasi, jadi kami tidak memperbaikinya"
Untuk apa karakter digunakan dalam CSS?Solusi. # karakter digunakan untuk membuat id di CSS.
Manakah yang bukan merupakan atribut CSS?The . not() CSS pseudo-class mewakili elemen yang tidak cocok dengan daftar pemilih. Karena mencegah item tertentu untuk dipilih, ini dikenal sebagai kelas semu negasi.
Apa yang bukan pemilih CSS yang valid?The . invalid pemilih memungkinkan Anda untuk memilih elemen
Bagaimana saya tidak menerapkan CSS ke suatu elemen?Dalam CSS, untuk mengecualikan kelas tertentu, kita dapat menggunakan kelas semu. not selector juga dikenal sebagai negasi pseudo-class atau not selector . Pemilih ini digunakan untuk mengatur gaya ke setiap elemen yang tidak ditentukan oleh pemilih yang diberikan. Karena digunakan untuk mencegah item tertentu dari daftar item yang dipilih. |