Satu baris kode untuk elemen ukuran otomatis dengan konten yang dapat diedit.
Tanpa field-sizing, untuk membuat kolom input berukuran tepat, Anda harus menebak ukuran rata-rata input kolom teks atau menggunakan JavaScript untuk menghitung karakter dan menambah tinggi atau lebar elemen saat pengguna memasukkan teks. Dengan
kata lain, hal ini tidak mudah, dan rentan terhadap error saat mencoba mengikuti
konten yang telah dimasukkan pengguna ke dalam input.
Dengan field-sizing, Anda memerlukan satu baris CSS untuk mengaktifkan penskalaan berdasarkan konten. Gaya penetapan ukuran berbasis konten ini juga berfungsi untuk lebih dari sekadar textarea.
textarea, select, input {
field-sizing: content;
}
Link cepat
Spesifikasi | Video Penjelasan
Menyukai video pendek?
Wes Bos dan
Jhey masing-masing memiliki video menarik di Twitter yang memperkenalkan field-sizing kepada Anda.
Elemen mana yang terpengaruh oleh penyesuaian ukuran kolom?
Berikut adalah daftar elemen
<form> yang dapat diproses oleh field-sizing, beserta ringkasan efeknya pada setiap elemen.
<textarea>
Input diciutkan menjadi min-inline-size atau agar sesuai dengan placeholder.
Saat pengguna mengetik, input akan bertambah besar ke arah inline hingga mencapai ukuran inline maksimum, yang kemudian teks akan di-wrap dan ukuran blok input akan bertambah besar agar sesuai dengan baris baru.
<select> dan <select multiple>
Elemen select akan menyusut agar sesuai dengan opsi yang dipilih.
Elemen select dengan atribut multiple akan bertambah besar agar sesuai dengan opsi terlebar dan setinggi yang diperlukan agar sesuai dengan jumlah opsi.
<input type="text">, <input type="email">, dan <input type="number">
Input diciutkan menjadi min-inline-size atau agar sesuai dengan placeholder.
Saat pengguna mengetik, input akan bertambah dalam arah inline hingga mencapai
max-inline-size, yang pada saat itu overflow akan memangkas nilai input.
<input type="file">
Input diciutkan ke tombol dan teks nama file yang telah diisi sebelumnya.
Setelah mengupload file, input akan menjadi selebar tombol ditambah teks nama file.
Melihat, menguji, dan membandingkan hasil
Berikut adalah contoh interaktif dan minimal dari perilaku sebelum dan sesudah
setiap elemen formulir, sebagaimana dipengaruhi oleh field-sizing.
Melihat lebih dekat
Saat menggunakan
[placeholder],
placeholder akan menjadi konten. Hal ini telah disebutkan sebelumnya, tetapi dijelaskan di sini karena penting untuk diketahui saat mengatur gaya formulir. Placeholder panjang atau pendek akan mengubah ukuran intrinsik input dengan field-sizing:
content.
Penanganan gaya kosong dan meluap
Menggunakan field-sizing berarti Anda harus melakukan beberapa pekerjaan tambahan. Ahmad Shadeed menyebutnya "CSS defensif", yang tujuannya tidak
harus menjelaskan secara persis bagaimana sesuatu harus berperilaku atau terlihat, melainkan untuk
melindunginya agar tidak masuk ke dalam kondisi visual yang tidak diinginkan. Sebelumnya, input memiliki
sejumlah ukuran tetap, tetapi setelah menerapkan field-sizing: content, input dapat menjadi terlalu kecil atau terlalu besar.
Gaya berikut adalah titik awal yang baik. Hal ini membantu elemen agar tidak
mengecil menjadi kotak yang terlalu kecil dan juga, dalam kasus textarea, tidak membesar
terlalu besar.
textarea {
min-block-size: 3.5rlh;
min-inline-size: 20ch;
max-inline-size: 50ch;
}
select {
min-inline-size: 5ch;
min-block-size: 1.5lh;
}
input {
min-inline-size: 7ch;
}
CSS ini menggunakan unit relatif untuk ukuran. Unit
lh
baru sangat cocok untuk ukuran blok dan
ch
berfungsi dengan baik untuk ukuran inline.
Berapa nilai default field-sizing?
Nilai default field-sizing adalah fixed, dan hanya menerima dua
nilai fixed atau content.