Rumah > hujung hadapan web > tutorial css > Bagaimana untuk Mengendalikan Kolon Dijana JSF dalam Pemilih CSS?

Bagaimana untuk Mengendalikan Kolon Dijana JSF dalam Pemilih CSS?

Barbara Streisand
Lepaskan: 2024-12-17 20:41:12
asal
433 orang telah melayarinya

How to Handle JSF-Generated Colons in CSS Selectors?

ID Elemen HTML Dijana JSF: Escape Colons dalam CSS Selectors

Apabila bekerja dengan JSF (JavaServer Faces), anda mungkin menghadapi ID elemen HTML dijana dengan titik bertindih (:). Ini boleh menyebabkan isu apabila menggunakan pemilih CSS, di mana titik bertindih menunjukkan permulaan pemilih pseudo.

Asal usul ID Dijajah:

JSF menjana ID klien untuk elemen HTML dengan lalai dalam bentuk "FormID:ElementID". Ini ialah cara mudah untuk mengendalikan ID yang bercanggah dalam aplikasi JSF.

Isu dengan Pemilih CSS:

Malangnya, titik bertindih dalam pemilih CSS mewakili permulaan pemilih pseudo , seperti :hover atau :first-child. Percubaan untuk menggunakan pemilih seperti #FormID:ElementID akan mengakibatkan ralat.

Penyelesaian:

1. Melarikan diri dari Colon dengan "" atau "3A":

#FormID\:ElementID {
  /* CSS styles */
}
Salin selepas log masuk
#FormIDA ElementID {
  /* CSS styles */
}
Salin selepas log masuk

2. Gunakan Pembungkus HTML dengan ID Biasa:

<div>
Salin selepas log masuk
#phoneWrapper table {
  /* CSS styles */
}
Salin selepas log masuk

3. Tukar UINamingContainer Separator:

Dalam JSF 2.x, anda boleh mengubah suai aksara pemisah lalai dalam bahagian konteks-param web.xml:

<context-param>
  <param-name>javax.faces.SEPARATOR_CHAR</param-name>
  <param-value>-</param-value>
</context-param>
Salin selepas log masuk

Ini akan berubah ID yang dijana kepada "FormID-ElementID", menjadikannya lebih serasi dengan CSS pemilih.

4. Lumpuhkan Prapending ID Borang:

Dalam JSF 1.2 atau lebih baru, anda boleh melumpuhkan pendahuluan ID borang dengan menambahkan prependId="false" pada teg h:form:

<h:form prependId="false">
  <h:dataTable>
Salin selepas log masuk

Walau bagaimanapun, pendekatan ini tidak disyorkan kerana ia boleh memberi kesan kepada fungsi AJAX.

5. Gunakan Kelas CSS:

<h:dataTable>
Salin selepas log masuk
.phone-table {
  /* CSS styles */
}
Salin selepas log masuk

Pengesyoran:

Untuk kebanyakan kes, disyorkan untuk melarikan diri dari kolon menggunakan aksara "". Ini ialah penyelesaian yang mudah dan serasi merentas penyemak imbas.

Atas ialah kandungan terperinci Bagaimana untuk Mengendalikan Kolon Dijana JSF dalam Pemilih CSS?. 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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan