Mengapa Anda Tidak Boleh Menghimpunkan Keturunan dalam Pemilih CSS?

Mary-Kate Olsen
Lepaskan: 2024-11-02 14:32:02
asal
625 orang telah melayarinya

Why Can't You Group Descendants in CSS Selectors?

Mengapa Anda Tidak Boleh Mengumpulkan Keturunan dalam Pemilih CSS?

Secara tradisinya, CSS tidak mempunyai kaedah yang cekap untuk menggunakan gaya yang sama kepada sekumpulan keturunan. Pertimbangkan jadual HTML berikut:

<code class="html"><table id='myTable'>
  <tr>
    <th></th>
    <th></th>
    <th></th>
  </tr>
  .
  .
  .
  <tr>
    <td></td>
    <td></td>
    <td></td>
  </tr>
</table></code>
Salin selepas log masuk

Untuk menggayakan kedua-dua tajuk lajur dan sel, pemilih tradisional memerlukan menentukan kedua-dua elemen:

<code class="css">#myTable th, #myTable td {}</code>
Salin selepas log masuk

Mengapa tidak ada sintaks yang lebih ringkas seperti :

<code class="css">#myTable (th,td) {}</code>
Salin selepas log masuk

Evolusi Penyelesaian

Pada mulanya, tiada cadangan untuk sintaks yang berguna sehingga 2008, apabila kelas pseudo :any() dicadangkan . Mozilla melaksanakannya sebagai :-moz-any() pada tahun 2010, diikuti dengan WebKit :-webkit-any() pada tahun 2011.

Walau bagaimanapun, menggunakan kedua-dua awalan secara serentak memerlukan set peraturan pendua, mengalahkan tujuan. Akibatnya, pemilih awalan ini kini dianggap tidak praktikal.

Draf kerja tahap 4 Pemilih kini mengandungi cadangan untuk :matches(), berdasarkan asal :any() tetapi dengan potensi peningkatan. Walau bagaimanapun, sokongan penyemak imbas dijangka mengambil sedikit masa.

Penyelesaian

Untuk menggayakan kedua-dua elemen th dan td secara khusus, anda boleh menggunakan * sebaliknya, dengan mengandaikan bahawa elemen tr mengandungi hanya elemen sel:

<code class="css">#myTable tr > * {}</code>
Salin selepas log masuk

Sebagai alternatif, atas sebab prestasi, anda mungkin lebih suka kaedah tradisional yang lebih panjang.

Atas ialah kandungan terperinci Mengapa Anda Tidak Boleh Menghimpunkan Keturunan dalam Pemilih CSS?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!