Heim Web-Frontend js-Tutorial Wie kann ich eine Redux-Aktion mit einem Timeout auslösen?

Wie kann ich eine Redux-Aktion mit einem Timeout auslösen?

Nov 27, 2024 am 07:57 AM

How to Dispatch a Redux Action with a Timeout?

Wie sende ich eine Redux-Aktion mit Timeout?

Problem:

Ich muss den Benachrichtigungsstatus meiner App mithilfe eines Timeout-Mechanismus aktualisieren. Bei Benachrichtigungen handelt es sich in der Regel um Fehler oder Meldungen. Ich muss nach 5 Sekunden eine weitere Aktion senden, um den Benachrichtigungsstatus in den Ausgangszustand zurückzusetzen, sodass die Benachrichtigung nicht angezeigt wird. Der Hauptgrund besteht darin, eine Funktion bereitzustellen, mit der Benachrichtigungen automatisch nach 5 Sekunden verschwinden.

Ich habe versucht, setTimeout zu verwenden und eine andere Aktion zurückzugeben, aber ohne Erfolg, und ich habe online keine entsprechenden Methoden gefunden. Ich bin bereit, alle Vorschläge auszuprobieren.

Antwort:

Sie müssen sich nicht darauf beschränken, alle Operationen in eine Funktionsbibliothek zu schreiben. Wenn Sie Timeouts in JavaScript verwenden möchten, verwenden Sie einfach setTimeout. Das gleiche Prinzip gilt für Redux-Aktionen.

Redux bietet zwar Alternativen für die Behandlung asynchroner Ereignisse, Sie sollten diese jedoch nur verwenden, wenn Sie feststellen, dass zu viel Code dupliziert wird. Sofern Sie nicht auf ein solches Problem stoßen, nutzen Sie einfach die Möglichkeiten der Sprache und verfolgen Sie die einfachste Lösung.

Asynchronen Code inline schreiben

Dies ist der einfachste Weg. Hier werden keine Redux-spezifischen Methoden verwendet.

store.dispatch({ type: 'SHOW_NOTIFICATION', text: 'You logged in.' })
setTimeout(() => {
  store.dispatch({ type: 'HIDE_NOTIFICATION' })
}, 5000)
Nach dem Login kopieren
Nach dem Login kopieren

Derselbe Vorgang wird in der verbundenen Komponente ausgeführt:

this.props.dispatch({ type: 'SHOW_NOTIFICATION', text: 'You logged in.' })
setTimeout(() => {
  this.props.dispatch({ type: 'HIDE_NOTIFICATION' })
}, 5000)
Nach dem Login kopieren
Nach dem Login kopieren

Der einzige Unterschied besteht darin, dass der Speicher selbst normalerweise nicht in der verbundenen Komponente zugänglich ist, sondern durch Injektion erhalten wird Requisiten an „dispatch()“ oder „Spezifischer Aktionsersteller“. Aber für uns macht es keinen Unterschied.

Wenn Sie beim Senden derselben Aktion in verschiedenen Komponenten keine Tippfehler machen möchten, können Sie den Aktionsersteller extrahieren, anstatt das Aktionsobjekt inline zu senden:

// actions.js
export function showNotification(text) {
  return { type: 'SHOW_NOTIFICATION', text }
}
export function hideNotification() {
  return { type: 'HIDE_NOTIFICATION' }
}

// component.js
import { showNotification, hideNotification } from '../actions'

this.props.dispatch(showNotification('You just logged in.'))
setTimeout(() => {
  this.props.dispatch(hideNotification())
}, 5000)
Nach dem Login kopieren
Nach dem Login kopieren

Oder, wenn Sie wurden zuvor über connect() gebunden:

this.props.showNotification('You just logged in.')
setTimeout(() => {
  this.props.hideNotification()
}, 5000)
Nach dem Login kopieren
Nach dem Login kopieren

Bisher haben wir keine Middleware oder andere fortgeschrittene Konzepte verwendet.

Extrahieren Sie den Ersteller der asynchronen Aktion

Die obige Methode funktioniert in einfachen Fällen gut, es können jedoch Probleme damit auftreten:

  • Es zwingt Sie, diese Logik überall dort zu duplizieren, wo Sie die Benachrichtigung anzeigen möchten.
  • Wenn es schnell genug ist, um zwei Benachrichtigungen anzuzeigen, haben diese Benachrichtigungen keine IDs, sodass eine Race Condition auftritt. Wenn die erste Zeitüberschreitung abläuft, wird fälschlicherweise eine HIDE_NOTIFICATION gesendet, wodurch die zweite Benachrichtigung vorzeitig ausgeblendet wird.

Um diese Probleme zu lösen, müssen Sie eine Funktion extrahieren, die Timeout-Logik zentralisieren und diese beiden Vorgänge ausführen. Wie unten gezeigt:

// actions.js
function showNotification(id, text) {
  return { type: 'SHOW_NOTIFICATION', id, text }
}
function hideNotification(id) {
  return { type: 'HIDE_NOTIFICATION', id }
}

let nextNotificationId = 0
export function showNotificationWithTimeout(dispatch, text) {
  // 为通知分配 ID,这样 reducer 就可以忽略不当前可见通知的 HIDE_NOTIFICATION。
  // 或者,我们可以存储超时 ID 并调用 clearTimeout(),但是我们仍然需要在一个地方执行此操作。
  const id = nextNotificationId++
  dispatch(showNotification(id, text))

  setTimeout(() => {
    dispatch(hideNotification(id))
  }, 5000)
}
Nach dem Login kopieren

Jetzt kann die Komponente Benachrichtigungen mithilfe von showNotificationWithTimeout anzeigen, ohne diese Logik wiederholen zu müssen oder Race-Bedingungen mit unterschiedlichen Benachrichtigungen haben zu müssen:

// component.js
showNotificationWithTimeout(this.props.dispatch, 'You just logged in.')

// otherComponent.js
showNotificationWithTimeout(this.props.dispatch, 'You just logged out.')    
Nach dem Login kopieren

showNotificationWithTimeout() Warum akzeptiert Versand als Der erste Parameter? Weil es Vorgänge an den Store senden muss. Komponenten haben normalerweise Zugriff auf den Versand, aber da wir möchten, dass die externe Funktion den Versandvorgang steuert, müssen wir ihr die Kontrolle geben.

Wenn Sie einen einzelnen Shop aus einem Modul exportiert haben, können Sie ihn importieren und den Sendevorgang direkt darin ausführen:

store.dispatch({ type: 'SHOW_NOTIFICATION', text: 'You logged in.' })
setTimeout(() => {
  store.dispatch({ type: 'HIDE_NOTIFICATION' })
}, 5000)
Nach dem Login kopieren
Nach dem Login kopieren

Sieht einfacher aus, aber wir empfehlen diese Methode nicht . Der Hauptgrund, warum es uns nicht gefällt, ist, dass es den Store dazu zwingt, ein Singleton zu sein. Dies macht die Implementierung von serverseitigem Rendering sehr schwierig. Auf der Serverseite möchten Sie, dass jede Anfrage über einen eigenen Speicher verfügt, sodass verschiedene Benutzer unterschiedliche vorinstallierte Daten erhalten.

Eine einzige Filiale erschwert auch das Testen. Sie können einen Store beim Testen von Aktionserstellern nicht mehr verspotten, da diese auf einen bestimmten realen Store verweisen, der aus einem bestimmten Modul exportiert wurde. Sie können den Status nicht einmal extern zurücksetzen.

Obwohl Sie technisch gesehen einen einzelnen Shop aus einem Modul exportieren können, empfehlen wir dies nicht. Tun Sie dies nicht, es sei denn, Sie sind sicher, dass Ihre App niemals serverseitiges Rendering hinzufügen wird.

Zurück zur vorherigen Version:

this.props.dispatch({ type: 'SHOW_NOTIFICATION', text: 'You logged in.' })
setTimeout(() => {
  this.props.dispatch({ type: 'HIDE_NOTIFICATION' })
}, 5000)
Nach dem Login kopieren
Nach dem Login kopieren

Dies löst das Problem der doppelten Logik und vermeidet Race Conditions.

Thunk-Middleware

Für einfache Anwendungen ist die obige Methode ausreichend. Wenn Sie damit zufrieden sind, machen Sie sich über die Middleware keine Sorgen.

Bei größeren Anwendungen kann es jedoch zu Unannehmlichkeiten kommen.

Zum Beispiel erscheint es unglücklich, den Versand weiterzugeben. Dies macht es schwieriger, Container- und Präsentationskomponenten zu entkoppeln, da jede Komponente, die Redux-Operationen wie oben beschrieben asynchron sendet, den Versand als Requisite akzeptieren muss, damit sie weitergegeben werden kann. Sie können connect() nicht mehr zum Binden eines Aktionserstellers verwenden, da showNotificationWithTimeout() nicht wirklich ein Aktionsersteller ist. Es werden keine Redux-Operationen zurückgegeben.

Außerdem kann es umständlich sein, sich zu merken, welche Funktionen synchrone Aktionsersteller sind (z. B. showNotification()) und welche asynchrone Hilfsfunktionen sind (z. B. showNotificationWithTimeout()). Sie müssen sie auf unterschiedliche Weise verwenden und darauf achten, sie nicht miteinander zu verwechseln.

Hier finden wir einen Weg, die Bereitstellung dieses Musters für Hilfsfunktionen zu „legitimieren“ und Redux dabei zu helfen, solche asynchronen Aktionsersteller als Sonderfall normaler Aktionsersteller zu „behandeln“ und nicht ausschließlich als Motivation für verschiedene Funktionen.

Wenn Sie immer noch darauf bestehen und glauben, dass dieses Problem in Ihrer eigenen Anwendung besteht, können Sie gerne die Redux Thunk-Middleware verwenden.

Einfach ausgedrückt bringt Redux Thunk Redux bei, spezielle Arten von Operationen zu erkennen, die tatsächlich Funktionen sind:

// actions.js
export function showNotification(text) {
  return { type: 'SHOW_NOTIFICATION', text }
}
export function hideNotification() {
  return { type: 'HIDE_NOTIFICATION' }
}

// component.js
import { showNotification, hideNotification } from '../actions'

this.props.dispatch(showNotification('You just logged in.'))
setTimeout(() => {
  this.props.dispatch(hideNotification())
}, 5000)
Nach dem Login kopieren
Nach dem Login kopieren

Wenn diese Middleware aktiviert ist, wenn Sie eine Funktion senden , übergibt die Redux Thunk-Middleware den Dispatch als Parameter an sie. Es „frisst“ auch solche Aktionen, also machen Sie sich keine Sorgen, dass Ihre Reduzierer seltsame Funktionsargumente erhalten. Ihre Reduzierer empfangen nur reguläre Objektoperationen – solche, die direkt oder, wie wir gerade beschrieben haben, von Funktionen gesendet werden.

Sieht aus, als wäre es nutzlos, nicht wahr? Nicht in diesem speziellen Fall. Aber es erlaubt uns, showNotificationWithTimeout() als regulären Redux-Aktionsersteller zu deklarieren:

this.props.showNotification('You just logged in.')
setTimeout(() => {
  this.props.hideNotification()
}, 5000)
Nach dem Login kopieren
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWie kann ich eine Redux-Aktion mit einem Timeout auslösen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

<🎜>: Bubble Gum Simulator Infinity - So erhalten und verwenden Sie Royal Keys
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Nordhold: Fusionssystem, erklärt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Mandragora: Flüstern des Hexenbaum
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Java-Tutorial
1673
14
PHP-Tutorial
1278
29
C#-Tutorial
1257
24
Python vs. JavaScript: Die Lernkurve und Benutzerfreundlichkeit Python vs. JavaScript: Die Lernkurve und Benutzerfreundlichkeit Apr 16, 2025 am 12:12 AM

Python eignet sich besser für Anfänger mit einer reibungslosen Lernkurve und einer kurzen Syntax. JavaScript ist für die Front-End-Entwicklung mit einer steilen Lernkurve und einer flexiblen Syntax geeignet. 1. Python-Syntax ist intuitiv und für die Entwicklung von Datenwissenschaften und Back-End-Entwicklung geeignet. 2. JavaScript ist flexibel und in Front-End- und serverseitiger Programmierung weit verbreitet.

JavaScript und das Web: Kernfunktionalität und Anwendungsfälle JavaScript und das Web: Kernfunktionalität und Anwendungsfälle Apr 18, 2025 am 12:19 AM

Zu den Hauptanwendungen von JavaScript in der Webentwicklung gehören die Interaktion der Clients, die Formüberprüfung und die asynchrone Kommunikation. 1) Dynamisches Inhaltsaktualisierung und Benutzerinteraktion durch DOM -Operationen; 2) Die Kundenüberprüfung erfolgt vor dem Einreichung von Daten, um die Benutzererfahrung zu verbessern. 3) Die Aktualisierung der Kommunikation mit dem Server wird durch AJAX -Technologie erreicht.

JavaScript in Aktion: Beispiele und Projekte in realer Welt JavaScript in Aktion: Beispiele und Projekte in realer Welt Apr 19, 2025 am 12:13 AM

Die Anwendung von JavaScript in der realen Welt umfasst Front-End- und Back-End-Entwicklung. 1) Zeigen Sie Front-End-Anwendungen an, indem Sie eine TODO-Listanwendung erstellen, die DOM-Operationen und Ereignisverarbeitung umfasst. 2) Erstellen Sie RESTFUFFUPI über Node.js und express, um Back-End-Anwendungen zu demonstrieren.

Verständnis der JavaScript -Engine: Implementierungsdetails Verständnis der JavaScript -Engine: Implementierungsdetails Apr 17, 2025 am 12:05 AM

Es ist für Entwickler wichtig, zu verstehen, wie die JavaScript -Engine intern funktioniert, da sie effizientere Code schreibt und Leistungs Engpässe und Optimierungsstrategien verstehen kann. 1) Der Workflow der Engine umfasst drei Phasen: Parsen, Kompilieren und Ausführung; 2) Während des Ausführungsprozesses führt die Engine dynamische Optimierung durch, wie z. B. Inline -Cache und versteckte Klassen. 3) Zu Best Practices gehören die Vermeidung globaler Variablen, die Optimierung von Schleifen, die Verwendung von const und lass und die Vermeidung übermäßiger Verwendung von Schließungen.

Python gegen JavaScript: Community, Bibliotheken und Ressourcen Python gegen JavaScript: Community, Bibliotheken und Ressourcen Apr 15, 2025 am 12:16 AM

Python und JavaScript haben ihre eigenen Vor- und Nachteile in Bezug auf Gemeinschaft, Bibliotheken und Ressourcen. 1) Die Python-Community ist freundlich und für Anfänger geeignet, aber die Front-End-Entwicklungsressourcen sind nicht so reich wie JavaScript. 2) Python ist leistungsstark in Bibliotheken für Datenwissenschaft und maschinelles Lernen, während JavaScript in Bibliotheken und Front-End-Entwicklungsbibliotheken und Frameworks besser ist. 3) Beide haben reichhaltige Lernressourcen, aber Python eignet sich zum Beginn der offiziellen Dokumente, während JavaScript mit Mdnwebdocs besser ist. Die Wahl sollte auf Projektbedürfnissen und persönlichen Interessen beruhen.

Python vs. JavaScript: Entwicklungsumgebungen und Tools Python vs. JavaScript: Entwicklungsumgebungen und Tools Apr 26, 2025 am 12:09 AM

Sowohl Python als auch JavaScripts Entscheidungen in Entwicklungsumgebungen sind wichtig. 1) Die Entwicklungsumgebung von Python umfasst Pycharm, Jupyternotebook und Anaconda, die für Datenwissenschaft und schnelles Prototyping geeignet sind. 2) Die Entwicklungsumgebung von JavaScript umfasst Node.JS, VSCODE und WebPack, die für die Entwicklung von Front-End- und Back-End-Entwicklung geeignet sind. Durch die Auswahl der richtigen Tools nach den Projektbedürfnissen kann die Entwicklung der Entwicklung und die Erfolgsquote der Projekte verbessert werden.

Die Rolle von C/C bei JavaScript -Dolmetschern und Compilern Die Rolle von C/C bei JavaScript -Dolmetschern und Compilern Apr 20, 2025 am 12:01 AM

C und C spielen eine wichtige Rolle in der JavaScript -Engine, die hauptsächlich zur Implementierung von Dolmetschern und JIT -Compilern verwendet wird. 1) C wird verwendet, um JavaScript -Quellcode zu analysieren und einen abstrakten Syntaxbaum zu generieren. 2) C ist für die Generierung und Ausführung von Bytecode verantwortlich. 3) C implementiert den JIT-Compiler, optimiert und kompiliert Hot-Spot-Code zur Laufzeit und verbessert die Ausführungseffizienz von JavaScript erheblich.

Python gegen JavaScript: Anwendungsfälle und Anwendungen verglichen Python gegen JavaScript: Anwendungsfälle und Anwendungen verglichen Apr 21, 2025 am 12:01 AM

Python eignet sich besser für Datenwissenschaft und Automatisierung, während JavaScript besser für die Entwicklung von Front-End- und Vollstapel geeignet ist. 1. Python funktioniert in Datenwissenschaft und maschinellem Lernen gut und unter Verwendung von Bibliotheken wie Numpy und Pandas für die Datenverarbeitung und -modellierung. 2. Python ist prägnant und effizient in der Automatisierung und Skripten. 3. JavaScript ist in der Front-End-Entwicklung unverzichtbar und wird verwendet, um dynamische Webseiten und einseitige Anwendungen zu erstellen. 4. JavaScript spielt eine Rolle bei der Back-End-Entwicklung durch Node.js und unterstützt die Entwicklung der Vollstapel.

See all articles