Aufbau eines Echtzeit-Benachrichtigungscenters in React
Benachrichtigungen halten Benutzer auf dem Laufenden und engagieren sie. Mit einem benutzerdefinierten React-Benachrichtigungscenter können Sie das Benutzererlebnis vollständig steuern und anpassen. Hier finden Sie eine kurze Anleitung zum Erstellen von Grund auf, die sowohl Frontend- als auch Backend-Komponenten für Echtzeit-Updates abdeckt.
1. Anforderungen an ein React Notification Center
- Echtzeit-Updates: Benachrichtigungen sollten sofort ohne Aktualisierung angezeigt werden.
- Hintergrundbenachrichtigungen: Verwenden Sie Servicemitarbeiter, um Benachrichtigungen zu bearbeiten, auch wenn die App nicht im Fokus ist.
- Multi-Channel-Unterstützung: Einschließlich In-App-Benachrichtigungen, Push-Benachrichtigungen, E-Mails und SMS.
- Benutzereinstellungen: Ermöglichen Sie Benutzern, ihre Benachrichtigungseinstellungen anzupassen.
- Skalierbarkeit: Stellen Sie sicher, dass das System eine große Menge an Benachrichtigungen verarbeiten kann.
- Zuverlässigkeit: Benachrichtigungen müssen genau und zeitnah zugestellt werden.
2. Überblick über die Systemarchitektur
Frontend
- React App: Zeigt Benachrichtigungen an und verarbeitet Echtzeit-Updates.
- Service Worker: Verwaltet Hintergrundbenachrichtigungen über die Benachrichtigungs-API.
- WebSocket/Polling: Hält den Benachrichtigungs-Feed in Echtzeit auf dem neuesten Stand.
Backend
-
Microservices:
- Benachrichtigungsdienst: Erzeugt und speichert Benachrichtigungen.
- Versanddienst: Sendet Benachrichtigungen an verschiedene Kanäle.
- Benutzereinstellungsdienst: Verwaltet Benutzereinstellungen für Benachrichtigungen.
- Nachrichtenwarteschlange: Verarbeitet effizient die Benachrichtigungsverteilung.
- Datenbank: Speichert Benutzereinstellungen und Benachrichtigungsprotokolle.
- Push-Dienste: Integration mit Firebase und APNs für Push-Benachrichtigungen.
3. Backend-Architektur
3.1. Microservices-Design
Microservice | Functionality |
---|---|
Notification Service | Generates and stores notifications |
Dispatch Service | Sends notifications to different channels |
User Preferences Service | Manages user settings and preferences |
3.2. Database Design
- Notifications Table: Stores notification metadata.
- User Preferences Table: Tracks user settings.
- Logs Table: Keeps a record of all notifications sent.
Example: Notification Service in Node.js/Express
const express = require('express'); const app = express(); let notifications = []; app.post('/notify', (req, res) => { const notification = { id: notifications.length + 1, type: req.body.type, message: req.body.message, userId: req.body.userId, status: 'unread', timestamp: new Date() }; notifications.push(notification); res.status(200).send(notification); }); app.listen(3000, () => { console.log('Notification Service running on port 3000'); });
4. Real-Time Communication
4.1. WebSocket Connection
- Server: Handles connections and broadcasts notifications.
- Client: Listens for updates and updates the UI in real-time.
Example: WebSocket Server with Socket.IO
const io = require('socket.io')(3001); io.on('connection', (socket) => { console.log('User connected:', socket.id); socket.emit('notification', { message: 'New notification!', timestamp: new Date() }); socket.on('disconnect', () => { console.log('User disconnected:', socket.id); }); });
Client-Side Integration in React
import React, { useEffect, useState } from 'react'; import io from 'socket.io-client'; const socket = io('http://localhost:3001'); function NotificationCenter() { const [notifications, setNotifications] = useState([]); useEffect(() => { socket.on('notification', (notification) => { setNotifications(prev => [...prev, notification]); }); }, []); return ( <div> <h2>Notification Center</h2> {notifications.map((notif, index) => ( <div key={index}>{notif.message} - {notif.timestamp}</div> ))} </div> ); } export default NotificationCenter;
4.2. Polling as a Fallback
- Client: Periodically checks the server for new notifications.
Example: Polling Implementation in React
import React, { useEffect, useState } from 'react'; function NotificationCenter() { const [notifications, setNotifications] = useState([]); useEffect(() => { const interval = setInterval(() => { fetch('/api/notifications') .then(response => response.json()) .then(data => setNotifications(data)); }, 5000); // Poll every 5 seconds return () => clearInterval(interval); }, []); return ( <div> <h2>Notification Center</h2> {notifications.map((notif, index) => ( <div key={index}>{notif.message}</div> ))} </div> ); } export default NotificationCenter;
5. Integrating Notifications API and Service Workers
5.1. Service Workers
- Register: Handle background notifications.
Example: Registering a Service Worker
if ('serviceWorker' in navigator) { navigator.serviceWorker.register('/sw.js').then(registration => { console.log('Service Worker registered:', registration.scope); }).catch(error => { console.error('Service Worker registration failed:', error); }); }
5.2. Notifications API
- Permission Handling: Request permission to display notifications.
- Trigger Notifications: Show notifications even when the app isn’t active.
Example: Displaying a Notification
if (Notification.permission === 'granted') { new Notification('New message!', { body: 'Click to view the message.', icon: '/path/to/icon.png' }); } else if (Notification.permission !== 'denied') { Notification.requestPermission().then(permission => { if (permission === 'granted') { new Notification('New message!', { body: 'Click to view the message.', icon: '/path/to/icon.png' }); } }); }
6. Push Notifications with Firebase and APNs
6.1. Firebase Cloud Messaging (FCM)
- Setup: Register with Firebase and get tokens.
- Send Notifications: Use tokens to dispatch notifications.
Example: Sending Push Notifications with FCM in Node.js
const admin = require('firebase-admin'); const serviceAccount = require('./path/to/serviceAccountKey.json'); admin.initializeApp({ credential: admin.credential.cert(serviceAccount) }); const message = { notification: { title: 'New Notification', body: 'You have a new notification!' }, token: 'device-token' }; admin.messaging().send(message) .then(response => console.log('Message sent:', response)) .catch(error => console.error('Error sending message:', error));
6.2. Apple Push Notification service (APNs)
- Integrate: Handle device tokens and use them to send notifications via APNs.
7. Building the Notification Center UI in React
7.1. Designing the Notification Feed
- Notification List: Show all notifications with options to mark as read or delete.
- Notification Badge: Display unread notification count.
- Toast Notifications: Use libraries like react-toastify for brief notifications.
Example: Notification List Component
import React from 'react'; function NotificationList({ notifications }) { return ( <div> {notifications.map(notification => ( <div key={notification.id}>{notification.message}</div> ))} </div> ); } export default NotificationList;
Example: Toast Notifications with react-toastify
import { toast } from 'react-toastify'; import 'react-toastify/dist/ReactToastify.css'; toast.configure(); function notify() { toast('New notification!', { position: toast.POSITION.BOTTOM_RIGHT }); } notify();
7.2. Managing State with Redux or Context API
- Global Store: Use Redux or Context API to manage notifications globally.
- Real-Time Updates: Update the store with new notifications via WebSocket or polling.
Example: Managing State with Redux
import { createSlice } from '@reduxjs/toolkit'; const notificationSlice = createSlice({ name: 'notifications', initialState: [], reducers: { addNotification: (state, action) => { state.push(action.payload); }, markAsRead: (state, action) => { const notification = state.find(n => n.id === action.payload); if (notification) { notification.read = true; } } } }); export const { addNotification, markAsRead } = notificationSlice.actions; export default notificationSlice.reducer;
As a good dev, you should go on to build the notification system in react from scratch, but, if your boss needs it ASAP and you’ve got a vacation planned (or just really need a break), check out my tool. It simplifies everything and gives you ready-to-use components as your new notifications API, available in all popular SDK. So you can chill while we handle the infra! ??
Das obige ist der detaillierte Inhalt vonAufbau eines Echtzeit-Benachrichtigungscenters in React. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undress AI Tool
Ausziehbilder kostenlos

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Stock Market GPT
KI-gestützte Anlageforschung für intelligentere Entscheidungen

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

In diesem Artikel wird vorgestellt, wie Sie JavaScript verwenden, um den Effekt des Klickens auf Bilder zu erreichen. Die Kernidee besteht darin, das Datenattribut von HTML5 zu verwenden, um den alternativen Bildpfad zu speichern und über JavaScript zu klicken und die SRC-Attribute dynamisch zu schalten, wodurch die Bildschaltung ermittelt wird. Dieser Artikel enthält detaillierte Code -Beispiele und -erklärungen, mit denen Sie diesen häufig verwendeten interaktiven Effekt verstehen und beherrschen können.

Überprüfen Sie zunächst, ob der Browser GeolocationAPI unterstützt. Wenn Sie unterstützt werden, rufen Sie GetCurrentPosition () auf, um die aktuellen Standortkoordinaten des Benutzers zu erhalten, und erhalten Sie die Werte mit Breiten- und Längengraden durch erfolgreiche Rückrufe. Geben Sie gleichzeitig Ausnahmen wie Ablehnungsberechtigung, Nichtverfügbarkeit des Standorts oder Zeitüberschreitung an. Sie können auch Konfigurationsoptionen übergeben, um eine hohe Präzision zu ermöglichen, und die Zeitüberschreitungs- und Cache -Gültigkeitsdauer festlegen. Der gesamte Prozess erfordert die Benutzerkennstellung und die entsprechende Fehlerbehandlung.

TheBestatorreateamulti-linestringinjavaScriptsisingisingTemPlatalalsWithbackttticks, die PREERDEVETICKS, die fürserverekeandexactlyAswrittens.

In diesem Tutorial wird ausführlich erläutert, wie Zahlen in Zeichenfolgen mit festen zwei Dezimalstellen in JavaScript formatiert werden. Auch Ganzzahlen können in Form von "#.00" angezeigt werden. Wir konzentrieren uns auf die Verwendung der Nummer.

Die NuXT3 -Kompositions -API -Kernverwendung umfasst: 1. DefinePagemeta, um Seiten -Meta -Informationen wie Titel, Layout und Middleware zu definieren. 2. Ushead wird verwendet, um Seiten -Header -Tags zu verwalten, unterstützt statische und reaktionsschnelle Updates und muss mit DefinePagemeta zusammenarbeiten, um die SEO -Optimierung zu erreichen. 3. UseasyncData wird verwendet, um sicher asynchrone Daten zu erhalten, den Lade- und Fehlerstatus automatisch zu verarbeiten und die Server- und Client -Datenerfassungssteuerung zu unterstützen. V.

Um ein Wiederholungsintervall in JavaScript zu erstellen, müssen Sie die Funktion "setInterval () verwenden, mit der Funktionen oder Codeblöcke in angegebenen Millisekunden -Intervallen wiederholt ausgeführt werden. SetInterval () => {console.log ("Alle 2 Sekunden ausführen");}, 2000) gibt eine Nachricht alle 2 Sekunden aus, bis sie durch ClearInterval (Intervalid) gelöscht wird. Es kann in tatsächlichen Anwendungen verwendet werden, um Uhren, Umfrageserver usw. zu aktualisieren, aber auf die Mindestverzögerungsgrenze und die Auswirkungen der Funktionsausführungszeit zu achten und das Intervall rechtzeitig zu löschen, wenn es nicht mehr benötigt wird, um Speicherleckage zu vermeiden. Vor allem vor der Deinstallation oder dem Schließen der Komponente stellen Sie sicher, dass dies sicherstellen

Dieser Artikel zielt darauf ab, das Problem der Rückgabe von Null zu lösen, wenn DOM -Elemente über document.getElementById () in JavaScript erhalten werden. Der Kern besteht darin, den Skriptausführungszeitpunkt und den DOM -Parsing -Status zu verstehen. Durch korrektes Platzieren des Tags oder die Verwendung des Domcontent -Ereignisses können Sie sicherstellen, dass das Element erneut versucht wird, wenn es verfügbar ist, und diese Fehler effektiv zu vermeiden.

Verwenden Sie die WriteText -Methode von ClipaPi, um Text in die Zwischenablage zu kopieren. Sie muss in Sicherheitskontext und Benutzerinteraktion aufgerufen werden, unterstützt moderne Browser und die alte Version kann mit Execcommand herabgestuft werden.
