Jadual Kandungan
Membina Borang Reaksi Terkawal
Mengapa memilih Formik?
Melaksanakan Formik
Kaedah 1: useFormik Hook
Pengesahan bentuk dengan formik
Kaedah 3: withFormik komponen pesanan lebih tinggi
Contoh praktikal
Memaparkan mesej ralat
Menjana nama pengguna
Kesimpulan
Rumah hujung hadapan web tutorial css Menggunakan Formik untuk mengendalikan borang dalam React

Menggunakan Formik untuk mengendalikan borang dalam React

Apr 07, 2025 am 10:00 AM

Menggunakan Formik untuk mengendalikan borang dalam React

Borang web adalah penting untuk laman web dan aplikasi. Walaupun bentuk HTML asli menawarkan fungsi asas, menguruskan keadaan, pengesahan, dan penyerahan mereka boleh menjadi kompleks. React, dengan pendekatan yang didorong oleh komponennya, memudahkan pengendalian bentuk tetapi masih boleh membawa kepada kod verbose. Formik, perpustakaan ringan, dengan elegan menangani cabaran -cabaran ini, memudahkan pengurusan negeri, pengesahan, dan penyerahan.

Artikel ini menunjukkan membina bentuk bertindak balas dengan Formik, mempamerkan keupayaannya untuk mengendalikan negara, pengesahan, dan penyerahan. Kami akan bermula dengan komponen reaksi asas dan kemudian mengintegrasikan Formik.

Membina Borang Reaksi Terkawal

Komponen React bergantung kepada keadaan dan prop. Elemen bentuk HTML mengekalkan keadaan dalaman melalui atribut value mereka. Ini menjadikan mereka komponen yang tidak terkawal -DOM menguruskan negara. Walau bagaimanapun, komponen terkawal , di mana React menguruskan negara, menawarkan kawalan yang lebih baik dan satu sumber kebenaran.

Borang HTML yang tidak terkawal mungkin kelihatan seperti ini:

<div class="formRow">
  <label for="email">Alamat e -mel</label>
  <input type="email" id="email">
</div>
<div class="formRow">
  <label for="password">Kata laluan</label>
  <input type="password" id="password">
</div>
<button type="submit">Hantar</button>
Salin selepas log masuk

Menukar ini ke komponen React yang dikawal:

 fungsi htmlform () {
  const [e -mel, setemail] = react.usestate ("");
  const [kata laluan, setpassword] = react.usestate ("");

  kembali (
    
Salin selepas log masuk
setemail (e.target.value)} />
setPassword (e.target.value)} />
); }

Pendekatan ini menyediakan satu sumber kebenaran untuk nilai bentuk, membolehkan pengesahan dan pengoptimuman prestasi yang lebih mudah.

Mengapa memilih Formik?

Banyak perpustakaan pengurusan bentuk wujud untuk bertindak balas (contohnya, bentuk cangkuk reaksi, bentuk redux). Formik membezakan dirinya melalui:

  1. Pendekatan Deklaratif: Abstraksi Memudahkan Negeri, Pengesahan, dan Penyerahan.
  2. Escape Hatch: Menyediakan kawalan apabila diperlukan, walaupun abstraksi.
  3. Negeri Terletak Bersama: Memelihara logik yang berkaitan dengan borang dalam komponen.
  4. Kesesuaian: Membolehkan menggunakan sebanyak atau sedikit dari Formik seperti yang diperlukan.
  5. Kemudahan Penggunaan: Mudah dan berkesan.

Mari kita mengintegrasikan Formik ke dalam komponen bentuk kami.

Melaksanakan Formik

Kami akan membuat borang log masuk asas, meneroka tiga kaedah penggunaan Formik:

  1. useFormik Hook
  2. Formik dengan konteks React (<formik></formik> )
  3. withFormik komponen pesanan lebih tinggi

Demo memerlukan pakej Formik dan Yup.

Kaedah 1: useFormik Hook

Bentuk semasa kami tidak berfungsi. useFormik Hook menyediakan fungsi dan pembolehubah Formik. Pembalakan nilai yang dikembalikan mendedahkan kandungannya.

Kami akan menggunakan useFormik dengan initialValues dan pengendali onSubmit :

 // Komponen React
fungsi baseFormik () {
  const formik = useFormik ({
    Nilai awal: {email: "", kata laluan: ""},
    onsubmit (nilai) {
      // Bentuk logik penyerahan
    }
  });

  kembali (
    
Salin selepas log masuk
Salin selepas log masuk
{/ * Form Elements */}
); }

Mengikat Formik untuk membentuk elemen:

 // Komponen React
fungsi baseFormik () {
  const formik = useFormik ({
    Nilai awal: {email: "", kata laluan: ""},
    onsubmit (nilai) {
      // Bentuk logik penyerahan
    }
  });

  kembali (
    
Salin selepas log masuk
Salin selepas log masuk
{/ * ... elemen bentuk lain */}
); }

Ini mengendalikan penyerahan ( onSubmit={formik.handleSubmit} ) dan keadaan input ( value , onChange melalui formik.getFieldProps ). Kami mengelakkan pengurusan negeri dan pengendalian acara manual. Memusnahkan getFieldProps dan handleSubmit meningkatkan lagi kejelasan kod.

The<formik></formik> Komponen menawarkan abstraksi selanjutnya dengan komponen terbina dalam seperti<field></field> ,<form></form> , dan<errormessage></errormessage> . Komponen ini menggunakan corak prop render.

 import {formik, medan, bentuk} dari 'formik';

fungsi formikrenderprops () {
  const initialValues ​​= {email: "", kata laluan: ""};

  const onsubmit = (nilai) => {
    amaran (json.stringify (nilai, null, 2));
  };

  kembali (
    <formik initialvalues="{initialValues}" onsubmit="{onSubmit}">
      {() => (
        <form>
          <field classname="email formField" name="email" type="email"></field>
          {/ * ... elemen bentuk lain */}
        </form>
      )}
    </formik>
  );
}
Salin selepas log masuk

Formik mengendalikan negeri dan penyerahan; Kami memberi tumpuan kepada struktur bentuk.

Pengesahan bentuk dengan formik

Formik menawarkan pengesahan di peringkat borang (menggunakan validate atau validationSchema ), tahap medan, atau dengan pencetus manual. Pengesahan peringkat borang mengesahkan keseluruhan borang sekaligus. validate adalah untuk pengesahan tersuai, manakala validationSchema menggunakan perpustakaan seperti Yup.

Contoh Menggunakan validate :

 const formik = useFormik ({
  // ...
  validate: () => {
    ralat const = {};
    jika (! formik.values.email) {errors.email = "diperlukan"; }
    // ... pengesahan lain
    kesilapan pulangan;
  },
  // ...
});
Salin selepas log masuk

Contoh Menggunakan validationSchema dengan Yup:

 const formik = useFormik ({
  // ...
  ValidationsChema: yup.object (). Bentuk ({
    E -mel: yup.string (). E -mel ("e -mel tidak sah"). Diperlukan ("Diperlukan"),
    // ... pengesahan lain
  }),
  // ...
});
Salin selepas log masuk

Pengesahan peringkat medan dan manual juga mungkin.

Kaedah 3: withFormik komponen pesanan lebih tinggi

withFormik adalah komponen pesanan yang lebih tinggi yang membungkus komponen borang anda.

Contoh praktikal

Mari kita gambarkan memaparkan mesej ralat dan menjana nama pengguna.

Memaparkan mesej ralat

Formik memudahkan paparan ralat. Semak Objek errors dan Paparan Mesej:

<label htmlfor="email">
  Alamat e -mel
  {formik.touched.email && formik.errors.email}
</label>
Salin selepas log masuk

Atau gunakan<errormessage></errormessage> :

<errormessage name="email"></errormessage>
Salin selepas log masuk

Menjana nama pengguna

setValues Formik boleh digunakan untuk menghasilkan nama pengguna dari e -mel:

 onsubmit (nilai) {
  formik.setValues ​​({... nilai, nama pengguna: `@$ {values.email.split ("@") [0]}`});
}
Salin selepas log masuk

Kesimpulan

Formik dengan ketara memudahkan pengendalian bentuk reaksi. Artikel ini merangkumi asas -asas; Terokai dokumentasi Formik untuk ciri -ciri canggih dan kes penggunaan.

Atas ialah kandungan terperinci Menggunakan Formik untuk mengendalikan borang dalam React. 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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

<🎜>: Bubble Gum Simulator Infinity - Cara Mendapatkan dan Menggunakan Kekunci Diraja
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Nordhold: Sistem Fusion, dijelaskan
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers of the Witch Tree - Cara Membuka Kunci Cangkuk Bergelut
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Tutorial Java
1672
14
Tutorial PHP
1277
29
Tutorial C#
1256
24
Perbandingan pembekal bentuk statik Perbandingan pembekal bentuk statik Apr 16, 2025 am 11:20 AM

Mari kita cuba menyusun istilah di sini: "Penyedia Borang Statik." Anda membawa html anda

Bukti konsep untuk menjadikan sass lebih cepat Bukti konsep untuk menjadikan sass lebih cepat Apr 16, 2025 am 10:38 AM

Pada permulaan projek baru, kompilasi SASS berlaku dalam sekejap mata. Ini terasa hebat, terutamanya apabila ia dipasangkan dengan BrowserSync, yang dimuat semula

Berita Platform Mingguan: Atribut Memuat HTML, Spesifikasi ARIA Utama, dan Bergerak Dari IFRAME ke Shadow Dom Berita Platform Mingguan: Atribut Memuat HTML, Spesifikasi ARIA Utama, dan Bergerak Dari IFRAME ke Shadow Dom Apr 17, 2025 am 10:55 AM

Pada minggu ini, berita platform, Chrome memperkenalkan atribut baru untuk memuatkan, spesifikasi aksesibiliti untuk pemaju web, dan gerakan BBC

Beberapa tangan dengan elemen dialog HTML Beberapa tangan dengan elemen dialog HTML Apr 16, 2025 am 11:33 AM

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

Kertas kerja Kertas kerja Apr 16, 2025 am 11:24 AM

Beli atau Membina adalah perdebatan klasik dalam teknologi. Membina barang sendiri mungkin berasa lebih murah kerana tidak ada item baris pada bil kad kredit anda, tetapi

Berita Platform Mingguan: Bookmarket Jarak Teks, Menunggu Tahap Teratas, Penunjuk Memuatkan AMP Baru Berita Platform Mingguan: Bookmarket Jarak Teks, Menunggu Tahap Teratas, Penunjuk Memuatkan AMP Baru Apr 17, 2025 am 11:26 AM

Pada minggu ini, roundup, sebuah bookmarklet yang berguna untuk memeriksa tipografi, menggunakan menunggu untuk mengamuk dengan cara modul JavaScript mengimport satu sama lain, ditambah Facebook &#039; s

Di manakah 'Langgan Podcast' pautan ke? Di manakah 'Langgan Podcast' pautan ke? Apr 16, 2025 pm 12:04 PM

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

Pilihan untuk menganjurkan analisis berasaskan bukan JavaScript anda sendiri Pilihan untuk menganjurkan analisis berasaskan bukan JavaScript anda sendiri Apr 15, 2025 am 11:09 AM

Terdapat banyak platform analisis untuk membantu anda mengesan data pelawat dan penggunaan di laman web anda. Mungkin paling penting Google Analytics, yang digunakan secara meluas

See all articles