Rumah > hujung hadapan web > tutorial js > Bagaimana untuk Melaksanakan Tindakan Redux Bermasa?

Bagaimana untuk Melaksanakan Tindakan Redux Bermasa?

Mary-Kate Olsen
Lepaskan: 2024-12-05 02:16:09
asal
370 orang telah melayarinya

How to Implement Timed Redux Actions?

Bagaimana untuk Menghantar Tindakan Redux dengan Tamat Masa?

Dalam Redux, anda boleh menggunakan setTimeout dan menghantar tindakan lain untuk mengembalikan keadaan pemberitahuan kepada keadaan asalnya selepas tempoh masa tertentu. Dengan cara ini, pemberitahuan hilang secara automatik selepas selang masa yang ditentukan.

Menggunakan JavaScript Sebaris

store.dispatch({ type: 'SHOW_NOTIFICATION', text: 'You logged in.' });
setTimeout(() => {
  store.dispatch({ type: 'HIDE_NOTIFICATION' });
}, 5000);
Salin selepas log masuk

Mengekstrak Pencipta Tindakan Async

Jika anda menghadapi pertindihan kod atau keadaan perlumbaan menggunakan pendekatan sebaris, pertimbangkan untuk mengekstrak tindakan async pencipta.

function showNotificationWithTimeout(dispatch, text) {
  const id = nextNotificationId++;
  dispatch(showNotification(id, text));

  setTimeout(() => {
    dispatch(hideNotification(id));
  }, 5000);
}
Salin selepas log masuk

Menggunakan Thunk Middleware

Untuk apl yang kompleks, anda mungkin mahu menggunakan perisian tengah Redux Thunk. Ia membolehkan Redux mengenali fungsi sebagai pencipta tindakan dan menyediakan akses kepada penghantaran dan getState dalam fungsi tersebut.

import { createStore, applyMiddleware } from 'redux';
import thunk from 'redux-thunk';

const store = createStore(
  reducer,
  applyMiddleware(thunk)
);

store.dispatch(showNotificationWithTimeout('You logged in.'));
Salin selepas log masuk

Keadaan Membaca dalam Thunks

Dalam pencipta tindakan thunk, anda boleh menggunakan getState untuk membaca keadaan semasa kedai. Ini berguna untuk tindakan menghantar bersyarat berdasarkan keadaan semasa.

showNotificationWithTimeout(dispatch, getState) {
  if (!getState().areNotificationsEnabled) {
    return;
  }
  // ... continue with action-dispatching logic
}
Salin selepas log masuk

Ingat untuk menggunakan teknik ini hanya apabila perlu, kerana JavaScript sebaris mudah mungkin mencukupi untuk banyak senario.

Atas ialah kandungan terperinci Bagaimana untuk Melaksanakan Tindakan Redux Bermasa?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan