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:
Penjelasan kodenya gini:
<Form> adalah component yang disediain React Router buat nge-handle form submission.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.name.db.updateProduct({ name }) (ini contoh aja).actionData, yang bisa lo akses di dalam component Products.action selesai dieksekusi tanpa error, semua loader data bakal di-revalidate supaya UI dan data tetep sinkron.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 :
fetcherKetika 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:
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.

Jadilah yang pertama untuk berdiskusi!