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:
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 methodPOST
,PUT
,PATCH
, atauDELETE
.request.formData()
dipake buat ambil data dari form yang di-submit. Karena lo pake<Form>
, maka tipe datanya adalahFormData
.- 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 componentProducts
. - 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 lewatactionData
.
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.