Actions

Data loading buat ngambil data, sedangkan action buat mutasi data. Sama kayak loader, action juga bisa dieksekusi di server lewat fungsi action atau di client lewat clientAction.

Bedanya dengan Server Actions di Next.js, actions di React Router nggak perlu ditaro di file khusus. Lo cuman perlu export fungsi action dari route module sama kayak lo export loader. Nantinya fungsi itu yang bakal dipanggil ketika ada form request.

Contohnya gini:

app/routes/admin/products.tsx

Penjelasan kodenya gini:

  • <Form> adalah component yang disediain React Router buat nge-handle form submission.
  • Ketika user submit form, hal ini yang terjadi:
    • action dieksekusi ketika ada form request dengan method POST, PUT, PATCH, atau DELETE.
    • request.formData() dipake buat ambil data dari form yang di-submit. Karena lo pake <Form>, maka tipe datanya adalah FormData.
    • Nama produk diambil dari form data dan disimpen ke variabel name.
    • Data produk di-update pake fungsi db.updateProduct({ name }) (ini contoh aja).
    • Terus data tersebut di-return sebagai actionData, yang bisa lo akses di dalam component Products.
    • Ketika action selesai dieksekusi tanpa error, semua loader data bakal di-revalidate supaya UI dan data tetep sinkron.
    • Terakhir, lo bisa akses nilai return dari action di dalam component lewat actionData.

Ketika lo pake <Form> buat submit form, dia bakal nambahin entry ke history browser, jadi user bisa kembali ke halaman sebelumnya pake tombol back di browser. Kalo lo nggak mau behavior ini, lo bisa pake yang namanya fetcher:

app/routes/admin/products.tsx

Ketika pake fetcher, buat ngambil data return dari action, lo bisa pake fetcher.data.

Di kasus nyata, lo biasanya butuh ngevalidasi data sebelum disimpen. Nggak ada cara spesial buat ini, standar aja kayak gini:

app/routes/admin/products.tsx

Ketika lo mau nge-return error dari action, lo bisa pake fungsi data dan ngasih status code yang sesuai. Hal ini diperluin supaya mencegah React Router nge-revalidate semua loader data yang ada di halaman tersebut.


Kamu Menyelesaikan Pelajaran Ini

Login untuk menyimpan progres belajarmu.


Kamu stuck? Ajukan pertanyaan!

Kolom ini hanya untuk pertanyaan terkait masalah yang mungkin kamu temui, tidak untuk yang lain.

Login untuk berkomentar 🔒

Markdown