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 :
fetcher
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:
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!