input:invalid {}
adalah berguna apabila elemen bentuk tidak sah, tetapi pengalaman pengguna adalah kurang apabila menggunakannya secara langsung. Sebagai contoh, gaya tidak sah dipaparkan dengan segera apabila beban borang, yang membingungkan pengguna. Oleh itu, penggunaan ini jarang berlaku dalam aplikasi praktikal. Walau bagaimanapun, jika masalah ini dielakkan, pemilih :invalid
boleh memainkan peranan yang besar dalam pengesahan bentuk tanpa bergantung pada perpustakaan besar.
Dave mencadangkan peningkatan berdasarkan idea asal dari 2017:
<code>form.errors :invalid { outline: 2px solid red; }</code>
Gaya ralat asli hanya digunakan selepas mengesahkan bahawa borang itu berada dalam keadaan ralat dan kelas errors
ditambah. Ujian juga mudah. Sebagai contoh, anda boleh menggunakan kelas ini apabila butang Hantar diklik:
<code>submitButton.addEventListener("click", (e) => { form.classList.toggle("errors", !form.checkValidity()) });</code>
Ia juga boleh digunakan apabila kotak input kehilangan fokus atau pada masa lain. Anda juga boleh membungkus setiap kotak input dalam pembalut dan menukar kelas pembalut apabila sesuai.
Dave menerapkan idea ini untuk Vue:
Kami menetapkan
errors
kepadafalse
apabila memulakan komponen borang kerana kami tidak mahu gaya yang salah dipaparkan sebelum pengguna mengemukakan borang tersebut. FungsiinvalidateForm
hanya menetapkanthis.error
ketrue
. Ini adalah salah satu kelemahanCSS :invalid
, ia terlalu mendesak. Dengan mendengar peristiwainvalid
, penggunaan gaya boleh ditangguhkan sehingga selepas percubaan penyerahan bentuk pertama, kita tahu bahawa terdapat ralat dalam borang.
Pendekatan ini tidak memerlukan perpustakaan tambahan, memanfaatkan sepenuhnya fungsi asli pengesahan bentuk HTML. Pautan berikut adalah versi yang lebih baik yang juga memaparkan mesej ralat:
Pautan Langsung →
Atas ialah kandungan terperinci Pengesahan bentuk html5 yang lebih bahagia di Vue. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Untuk sementara waktu, iTunes adalah anjing besar dalam podcasting, jadi jika anda mengaitkan "Langgan Podcast" untuk suka:

Kami kehilangan opera ketika mereka pergi Chrome pada tahun 2013. Sama dengan Edge ketika ia juga menjadi Chrome awal tahun ini. Mike Taylor memanggil perubahan ini "menurun

Dari laman web Trashy Clickbait hingga paling banyak penerbitan, butang saham telah lama di mana -mana di seluruh web. Namun ia boleh dikatakan bahawa ini

Dalam roundup minggu ini, Apple masuk ke dalam komponen web, bagaimana Instagram adalah skrip insta-loading, dan beberapa makanan untuk difikirkan untuk sumber kritikal sendiri.

Apabila saya melihat melalui dokumentasi arahan git, saya perhatikan bahawa banyak daripada mereka mempunyai pilihan untuk. Saya pada mulanya berpendapat bahawa ini hanya

Bunyi seperti masalah yang sukar tidak? Kami sering tidak mempunyai tembakan produk dalam beribu -ribu warna, supaya kita dapat membalikkannya. Kami juga tidak

Saya suka apabila laman web mempunyai pilihan mod gelap. Mod gelap menjadikan laman web lebih mudah bagi saya untuk membaca dan membantu mata saya berasa lebih santai. Banyak laman web, termasuk

Ini saya melihat elemen HTML untuk kali pertama. Saya telah menyedarinya untuk seketika, tetapi Haven ' t mengambilnya untuk putaran lagi. Ia mempunyai cukup keren dan


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Versi Mac WebStorm
Alat pembangunan JavaScript yang berguna

Penyesuai Pelayan SAP NetWeaver untuk Eclipse
Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.

VSCode Windows 64-bit Muat Turun
Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Muat turun versi mac editor Atom
Editor sumber terbuka yang paling popular