Bina nama kelas secara dinamik dalam TailwindCss
P粉147747637
2023-08-24 10:11:17
<p>Saya sedang membina perpustakaan komponen menggunakan TailwindCss untuk projek saya yang seterusnya, dan saya baru sahaja menghadapi masalah kecil dengan komponen Button. </p>
<p>Saya lulus prop seperti <code>'primary'</code> atau <code>'secondary'</code> yang berfungsi sama seperti yang saya lakukan dalam <code>tailwind.config. js< ;/code> dan kemudian saya mahu menetapkannya kepada komponen butang menggunakan <code>Template Lites</code> ;
<pre class="brush:php;toolbar:false;"><butang
Nama kelas={`
w-40 bulat-lg p-3 m-2 fon-peralihan tebal-semua tempoh-100 jidar-2 aktif:skala-[0.98]
bg-${color}-500 `}
onClick={onClick}
type="butang"
tabIndex={0}
>
{anak-anak}
</button></pre>
<p>Nama kelas dipaparkan dengan baik dalam penyemak imbas, ia menunjukkan <kod>bg-primary-500</code> dalam DOM, tetapi tidak dalam tab Gaya Gunaan. </p>
<p>Konfigurasi tema adalah seperti berikut:</p>
<pre class="brush:php;toolbar:false;">tema: {
lanjutkan: {
warna: {
utama: {
500: '#B76B3F',
},
menengah: {
500: '#344055',
},
},
},
},</pre>
<p>Tetapi ia tidak menggunakan sebarang gaya. Jika saya hanya menambah <code>bg-primary-500</code> ia berfungsi dengan baik. </p>
<p>Sejujurnya, saya hanya tertanya-tanya sama ada ini kerana pengkompil JIT tidak mengambil nama kelas dinamik atau jika saya melakukan sesuatu yang salah (atau jika ini bukan cara untuk menggunakan tailWind). </p>
<p>Sebarang bantuan dialu-alukan, terima kasih terlebih dahulu! </p>
Tidak disyorkan untuk menulis kelas CSS Tailwind dengan cara ini. Walaupun mod JIT tidak disokong , untuk memetik dokumentasi Tailwind CSS: "Tailwind tidak termasuk apa-apa jenis masa jalan klien, jadi nama kelas perlu diekstrak secara statik pada masa binaan dan tidak boleh dipercayai dalam klien "
Jadi selepas mengetahui bahawa cara kerja ini tidak digunakan dan JIT tidak menyokongnya (terima kasih kepada pengulas yang murah hati). Saya telah menukar pendekatan kepada pendekatan yang lebih berasaskan "konfigurasi".
Pada asasnya, saya mentakrifkan const dengan konfigurasi asas prop yang berbeza dan menerapkannya pada komponen. Ini memerlukan lebih banyak penyelenggaraan, tetapi ia menyelesaikan kerja.
Ini ialah contoh konfigurasi. (tiada menaip diperlukan buat masa ini) dan beberapa pemfaktoran semula yang lebih baik, tetapi anda akan mendapat idea itu.
Kemudian saya menerapkan gaya seperti ini: