」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 如何在 React 中使用廣播通道 API

如何在 React 中使用廣播通道 API

發佈於2024-11-08
瀏覽:325

在當今的 Web 應用程式中,跨多個選項卡或視窗保持資訊更新可以大大增強使用者體驗。例如,如果使用者在一個選項卡中登出,您希望該操作反映在所有其他選項卡中。 廣播通道 API 透過允許同一來源的不同瀏覽上下文之間進行通信,使這一過程變得簡單。本文將指導您如何在 React 應用程式中使用此 API。

什麼是廣播頻道 API?

廣播頻道 API 是一種在同一網站的不同標籤、視窗或 iframe 之間實現通訊的簡單方法。它允許您向同一頻道上偵聽的所有其他上下文廣播訊息,使其成為即時更新和同步的理想選擇。

How to Use Broadcast Channel API in React

為什麼要用它?

即時更新:跨不同選項卡同步數據,例如使用者會話。

易於整合:可以輕鬆添加到現有的 React 應用程式中。

無附加函式庫:在現代瀏覽器中原生運行,無需額外依賴。

在 React 中設定廣播頻道 API

讓我們透過建立自訂掛鉤來管理通訊來演練如何在 React 應用程式中使用 Broadcast Channel API。

建立自訂 Hook

首先,建立一個名為useBroadcastChannel的自訂鉤子來封裝Broadcast Channel邏輯。

import { useEffect, useState } from 'react';

const useBroadcastChannel = (channelName) => {
    const [message, setMessage] = useState(null);
    const channel = new BroadcastChannel(channelName);

    useEffect(() => {
        const handleMessage = (event) => {
            setMessage(event.data);
        };

        channel.onmessage = handleMessage;

        // Clean up the channel when the component unmounts
        return () => {
            channel.close();
        };
    }, [channel]);

    const sendMessage = (msg) => {
        channel.postMessage(msg);
    };

    return { message, sendMessage };
};

export default useBroadcastChannel;

這個鉤子建立一個新的BroadcastChannel,監聽傳入的訊息,並提供發送訊息的功能。

在 React 元件中使用 Hook

讓我們在 React 元件中使用自訂掛鉤來管理不同選項卡之間的登入工作階段。

import React, { useEffect } from 'react';
import useBroadcastChannel from './useBroadcastChannel';

const AuthManager = () => {
    const { message, sendMessage } = useBroadcastChannel('auth_channel');

    const handleLogin = () => {
        // Notify all tabs that the user has logged in
        sendMessage({ type: 'login', user: 'JohnDoe' });
    };

    const handleLogout = () => {
        // Notify all tabs that the user has logged out
        sendMessage({ type: 'logout' });
    };

    useEffect(() => {
        if (message) {
            if (message.type === 'logout') {
                alert('You have been logged out in another tab!');
            }
        }
    }, [message]);

    return (
        

Authentication Manager

); }; export default AuthManager;

此 AuthManager 元件使用 useBroadcastChannel 掛鉤來處理跨選項卡的使用者驗證狀態。當使用者登入或登出時,一則訊息將會傳送到 auth_channel 通道上的所有其他標籤。如果在任何標籤中收到註銷訊息,則會觸發警報以通知使用者。

結論

Broadcast Channel API 提供了一種在 Web 應用程式中跨多個標籤或視窗同步資料的簡單方法。透過使用自訂 React hook,您可以輕鬆管理即時訊息傳遞並改善使用者體驗。無論您是處理登入狀態還是同步其他類型的數據,廣播通道 API 都可以簡化跨選項卡通訊。

延伸閱讀

• 廣播頻道 API 上的 MDN Web 文件

與我聯絡

  • 領英

  • 嘰嘰喳喳

  • GitHub

版本聲明 本文轉載於:https://dev.to/sachinchaurasiya/how-to-use-broadcast-channel-api-in-react-5eec?1如有侵犯,請洽[email protected]刪除
最新教學 更多>
  • 大批
    大批
    方法是可以在物件上呼叫的 fns 數組是對象,因此它們在 JS 中也有方法。 slice(begin):將陣列的一部分提取到新數組中,而不改變原始數組。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index ...
    程式設計 發佈於2025-01-07
  • 如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    在 PHP 中組合關聯數組在 PHP 中,將兩個關聯數組組合成一個數組是常見任務。考慮以下請求:問題描述:提供的代碼定義了兩個關聯數組,$array1 和 $array2。目標是建立一個新陣列 $array3,它合併兩個陣列中的所有鍵值對。 此外,提供的陣列具有唯一的 ID,而名稱可能重疊。要求是建...
    程式設計 發佈於2025-01-07
  • 儘管程式碼有效,為什麼 POST 請求無法擷取 PHP 中的輸入?
    儘管程式碼有效,為什麼 POST 請求無法擷取 PHP 中的輸入?
    解決PHP 中的POST 請求故障在提供的程式碼片段中:action=''而非:action="<?php echo $_SERVER['PHP_SELF'];?>";?>"檢查$_POST陣列:表單提交後使用 var_dump 檢查 $_POST 陣列的內...
    程式設計 發佈於2025-01-07
  • Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta:列偏移的刪除和恢復Bootstrap 4 在其Beta 1 版本中引入了重大更改柱子偏移了。然而,隨著 Beta 2 的後續發布,這些變化已經逆轉。 從 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    程式設計 發佈於2025-01-07
  • HTML 格式標籤
    HTML 格式標籤
    HTML 格式化元素 **HTML Formatting is a process of formatting text for better look and feel. HTML provides us ability to format text without us...
    程式設計 發佈於2025-01-07
  • 在 Go 中使用 WebSocket 進行即時通信
    在 Go 中使用 WebSocket 進行即時通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSocke...
    程式設計 發佈於2025-01-07
  • 插入資料時如何修復「常規錯誤:2006 MySQL 伺服器已消失」?
    插入資料時如何修復「常規錯誤:2006 MySQL 伺服器已消失」?
    插入記錄時如何解決「一般錯誤:2006 MySQL 伺服器已消失」介紹:將資料插入MySQL 資料庫有時會導致錯誤「一般錯誤:2006 MySQL 伺服器已消失」。當與伺服器的連線遺失時會出現此錯誤,通常是由於 MySQL 配置中的兩個變數之一所致。 解決方案:解決此錯誤的關鍵是調整wait_tim...
    程式設計 發佈於2025-01-07
  • 如何根據特定屬性尋找並取代 JavaScript 陣列中的物件?
    如何根據特定屬性尋找並取代 JavaScript 陣列中的物件?
    在物件陣列中尋找具有特定屬性的物件在Javascript 中,可以在未命名物件陣列中搜尋特定屬性基於屬性值匹配的物件。考慮以下數組:var array = [ { name:"string 1", value:"this", other: "...
    程式設計 發佈於2025-01-06
  • 為什麼我的 MySQL LOAD_FILE 函數會無提示地失敗?
    為什麼我的 MySQL LOAD_FILE 函數會無提示地失敗?
    使用 LOAD_FILE 將檔案匯入 MySQL Blob - 故障排除LOAD_FILE 函數可讓您讀取檔案並將其載入至 MySQL斑點。然而,用戶在使用此功能時有時會遇到問題,儘管沒有收到錯誤訊息。 根據 MySQL 文檔,LOAD_FILE 必須滿足某些條件才能正常運作:文件必須駐留在伺服器主...
    程式設計 發佈於2025-01-06
  • 如何有效率地從 JavaScript 物件中取得鍵數組?
    如何有效率地從 JavaScript 物件中取得鍵數組?
    從物件以陣列形式擷取鍵在JavaScript 中,可以透過多種方法實作將物件的鍵擷取到陣列中。雖然提供的使用 for-in 迴圈的程式碼片段是有效的,但它可能不是最簡潔或最有效的方法。 使用 Object.keys()A更簡潔、更現代的方法是利用內建的 Object.keys() 函數。此函數直接傳...
    程式設計 發佈於2025-01-06
  • 如何使用外部 CSS 覆蓋 HTML 中的內聯樣式?
    如何使用外部 CSS 覆蓋 HTML 中的內聯樣式?
    使用外部CSS 覆蓋內聯樣式使用包含內聯樣式的HTML 標記時,您可能會遇到需要覆蓋這些樣式的情況使用外部CSS 的樣式。但是,應用常規 CSS 規則可能並不總是按預期工作。 要有效覆蓋內聯樣式,您可以在 CSS 規則中使用 !important 關鍵字。此關鍵字為規則添加了更高的優先級,使其即使在...
    程式設計 發佈於2025-01-06
  • Go語言的Hello World
    Go語言的Hello World
    如果您剛剛涉足 Go(Golang),那麼最好的起點一如既往地是永恆的“Hello, World!”程序。這個簡單的練習不僅僅是一種傳統;它清楚地介紹了 Go 的簡潔語法、強大的標準庫和極簡方法。 package main import "fmt" func main() { fmt.Pr...
    程式設計 發佈於2025-01-06
  • 使用本機包時,為什麼我的 Docker 映像建置失敗並顯示“導入路徑不以主機名稱開頭”?
    使用本機包時,為什麼我的 Docker 映像建置失敗並顯示“導入路徑不以主機名稱開頭”?
    Building Docker Image 與 Local Package: Error "Import Path Does Not Begin with Hostname"When attempting to build a docker imdage with a local...
    程式設計 發佈於2025-01-06
  • 形狀 - CSS 挑戰
    形狀 - CSS 挑戰
    您可以在倉庫 Github 上找到本文中的所有代碼。 您可以在此處查看 CodeSandbox 的視覺效果。 透過CSS繪製各種形狀 如何在CSS中繪製正方形、梯形、三角形、異形三角形、扇形、圓形、半圓、定寬高比、0.5px線? <!DOCTYPE html> &l...
    程式設計 發佈於2025-01-06
  • Go可以建立共享庫嗎?
    Go可以建立共享庫嗎?
    在Go 中建立共享庫共享庫,或動態連結庫(.so 檔案),允許單獨的程式共享公共程式碼和數據,節省記憶體並提高效能。雖然 C 和 C 語言長期以來都支援建立共享庫,但在 Go 中卻不太簡單。 Go 中可以建立共享庫嗎? 是的,可以使用 -linkshared 標誌在 Go 中建立共享庫。此標誌允許 ...
    程式設計 發佈於2025-01-06

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3