欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript常見的跨標簽頁通信方式總結

 更新時間:2023年10月27日 09:42:38   作者:前端俊剛  
跨標簽頁通信是指在瀏覽器中的不同標簽頁之間進行數據傳遞和通信的過程,這篇文章為大家整理了前端常見的跨標簽頁通信方式,有需要的小伙伴可以了解下

引言

跨標簽頁通信是指在瀏覽器中的不同標簽頁之間進行數據傳遞和通信的過程。在傳統的Web開發(fā)中,每個標簽頁都是相互獨立的,無法直接共享數據。然而,有時候我們需要在不同的標簽頁之間進行數據共享或者實現一些協同操作,這就需要使用跨標簽頁通信來實現。

常見的跨標簽頁方案如下

  • BroadCast Channel
  • Service Worker
  • LocalStorage window.onstorage 監(jiān)聽
  • window.open、window.postMessage
  • Shared Worker 定時器輪詢( setInterval )
  • IndexedDB 定時器輪詢( setInterval )
  • cookie 定時器輪詢( setInterval )
  • Websocket

本文先介紹前面4種

BroadCast Channel

Broadcast Channel API 可以實現同源下瀏覽器不同窗口,Tab 頁,frame 或者 iframe 下的(通常是同一個網站下不同的頁面) 之間的簡單通訊。

通過創(chuàng)建一個監(jiān)聽某個頻道下的 BroadcastChannel對象,你可以接收發(fā)送給該頻道的所有消息。一個有意思的點是,你不需要再維護需要通信的 iframe 或 worker 的索引。它們可以通過構造 BroadcastChannel 來簡單地“訂閱”特定頻道,并在它們之間進行全雙工(雙向)通信。

示例

通過創(chuàng)建一個廣播頻道,并在不同的標簽頁中監(jiān)聽該頻道,可以實現跨標簽頁通信。

例如,在一個標簽頁中發(fā)送消息:

const channel = new BroadcastChannel('myChannel');
channel.postMessage('Hello from Tab 1!');

在另一個標簽頁中接收消息:

const channel = new BroadcastChannel('myChannel');
channel.onmessage = function(event) {
  console.log(event.data); // 輸出:Hello from Tab 1!
};

可以通過調用 BroadcastChannel 對象的 close()方法,可以離開頻道。這將斷開該對象和其關聯的頻道之間的聯系,并允許它被垃圾回收。

// 斷開頻道連接
channel.close();

Service Worker

Service worker 本質上充當 Web 應用程序、瀏覽器與網絡(可用時)之間的代理服務器。這個 API 旨在創(chuàng)建有效的離線體驗,它會攔截網絡請求并根據網絡是否可用來采取適當的動作、更新來自服務器的的資源。它還提供入口以推送通知和訪問后臺同步 API。

Service worker 是一個注冊在指定源和路徑下的事件驅動worker。它采用 JavaScript 文件的形式,控制關聯的頁面或者網站,攔截并修改訪問和資源請求,細粒度地緩存資源。你可以完全控制應用在特定情形(最常見的情形是網絡不可用)下的表現。

使用 ServiceWorkerContainer.register() 方法首次注冊 service worker。如果注冊成功,service worker 就會被下載到客戶端并嘗試安裝或激活,這將作用于整個域內用戶可訪問的 URL,或者其特定子集。

示例

index.html

<body>
    <h1>頁面一</h1>
    <button>發(fā)送</button>
    <script>
        navigator.serviceWorker.register('./sw.js')
            .then(() => {
                console.log("service worker 注冊成功");
            });
        document.querySelector("button").onclick = function () {
            navigator.serviceWorker.controller.postMessage('hello');
        }
    </script>
</body>

index2.html

<body>
    <h1>頁面二</h1>
    <script>
        navigator.serviceWorker.register('./sw.js')
            .then(() => {
                console.log("service worker 注冊成功");
            });
        navigator.serviceWorker.onmessage = function ({ data }) {
            console.log(data);
        }
    </script>
</body>

sw.js

self.addEventListener("message",async event=>{
    const clients = await self.clients.matchAll();
    clients.forEach(function(client){
        client.postMessage(event.data)
    });
});

LocalStorage window.onstorage

存儲在 localStorage 的數據可以長期保留;而當頁面會話結束——也就是說,當頁面被關閉時,存儲在 sessionStorage 的數據會被清除。

另外,localStorage 中的鍵值對總是以字符串的形式存儲。 (需要注意,和 js 對象相比,鍵值對總是以字符串的形式存儲意味著數值類型會自動轉化為字符串類型).

當存儲區(qū)域(localStorage 或 sessionStorage)被修改時,將觸發(fā) storage 事件。

由事件監(jiān)聽器發(fā)送給回調函數的事件對象有幾個屬性如下:

PropertyTypeDescription
target 只讀[EventTarget]事件目標 (DOM 樹中的最大目標)
type 只讀[DOMString]事件的類型
bubbles 只讀[Boolean]事件通常是否會出現冒泡
cancelable 只讀[Boolean]事件是否可取消
key 只讀[DOMString] (string)鍵更改時
oldValue 只讀[DOMString] (string)正在更改鍵的舊值
newValue 只讀[DOMString] (string)正在更改鍵的新值
url 只讀DOMString鍵更改的文檔的地址
storageArea 只讀[Storage]受影響的存儲對象

示例

例如,在一個標簽頁中修改LocalStorage的值:

localStorage.setItem('message', 'Hello from Tab 1!');

在另一個標簽頁中監(jiān)聽LocalStorage的變化:

window.onstorage = function(event) {
  if (event.key === 'message') {
    console.log(event.newValue); // 輸出:Hello from Tab 1!
  }
};

window.open、window.postMessage

通過在一個標簽頁中使用window.open打開另一個標簽頁,并使用window.postMessage進行消息傳遞,可以實現跨標簽頁通信。

window.open()

open()
open(url)
open(url, target)
open(url, target, windowFeatures)
  • url: 一個字符串,表示要加載的資源的 URL 或路徑。如果指定空字符串("")或省略此參數,則會在目標瀏覽上下文中打開一個空白頁。
  • target: 一個不含空格的字符串,用于指定加載資源的瀏覽上下文的名稱。
  • windowFeatures: 一個字符串,包含以逗號分隔的窗口特性列表。

window.postMessage()  方法可以安全地實現跨源通信。通常,對于兩個不同頁面的腳本,只有當執(zhí)行它們的頁面位于具有相同的協議(通常為 https),端口號(443 為 https 的默認值),以及主機 (兩個頁面的模數 Document.domain設置為相同的值) 時,這兩個腳本才能相互通信。window.postMessage()  方法提供了一種受控機制來規(guī)避此限制,只要正確的使用,這種方法就很安全。

示例

例如,在一個標簽頁中發(fā)送消息:

const newTab = window.open('other.html');
newTab.postMessage('Hello from Tab 1!', '*');

在另一個標簽頁中接收消息:

window.addEventListener('message', function(event) {
  console.log(event.data); // 輸出:Hello from Tab 1!
});

總結

  • BroadCast Channel:使用Broadcast Channel API可以在不同的瀏覽器上下文之間進行消息廣播和接收。通過創(chuàng)建一個廣播頻道,并在不同的標簽頁中監(jiān)聽該頻道,可以實現跨標簽頁通信。
  • Service Worker:Service Worker是一種在瀏覽器后臺運行的腳本,可以攔截和處理網絡請求。通過在Service Worker中監(jiān)聽和處理消息事件,可以實現跨標簽頁通信。
  • LocalStorage window.onstorage 監(jiān)聽:通過在不同的標簽頁中監(jiān)聽LocalStorage的變化,可以實現跨標簽頁通信。當一個標簽頁修改LocalStorage的值時,其他標簽頁可以通過監(jiān)聽storage事件來獲取最新值。
  • window.open、window.postMessage:通過在一個標簽頁中使用window.open打開另一個標簽頁,并使用window.postMessage進行消息傳遞,可以實現跨標簽頁通信。這種方式適用于需要直接傳遞數據或消息的場景。

這些方案各有特點和適用場景。Broadcast Channel適用于需要實時廣播消息給所有打開的標簽頁的場景;Service Worker適用于需要在后臺進行數據處理或者發(fā)送消息給其他標簽頁的場景;LocalStorage window.onstorage監(jiān)聽適用于需要共享數據并及時獲取更新的場景;window.open、window.postMessage適用于需要直接傳遞數據或消息的場景。

到此這篇關于JavaScript常見的跨標簽頁通信方式總結的文章就介紹到這了,更多相關JavaScript跨標簽頁通信內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • webpack常用配置項配置文件介紹

    webpack常用配置項配置文件介紹

    這篇文章主要為大家詳細介紹了webpack常用配置項配置文件,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-11-11
  • Javascript實現跨域后臺設置攔截的方法詳解

    Javascript實現跨域后臺設置攔截的方法詳解

    這篇文章主要給大家介紹了關于Javascript實現跨域后臺設置攔截的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面跟著小編來一起學習學習吧。
    2017-08-08
  • javascript的this關鍵字詳解

    javascript的this關鍵字詳解

    這篇文章主要介紹了javascript的this關鍵字的用法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-05-05
  • JS module的導出和導入的實現代碼

    JS module的導出和導入的實現代碼

    這篇文章主要介紹了JS module的導出和導入的實現代碼,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-02-02
  • JavaScript如何使用dhtmlXTreeObject的loadJSONObject繪制目錄樹

    JavaScript如何使用dhtmlXTreeObject的loadJSONObject繪制目錄樹

    這篇文章主要介紹了JavaScript如何使用dhtmlXTreeObject的loadJSONObject繪制目錄樹,需要引入dhtmlXTreeObject的css和js文件,這里還需要注意js的引用順序,本文給大家介紹的非常詳細,需要的的朋友參考下吧
    2023-11-11
  • uni-app封裝組件實現下方滑動彈出模態(tài)框效果

    uni-app封裝組件實現下方滑動彈出模態(tài)框效果

    這篇文章主要介紹了uni-app封裝組件實現下方滑動彈出模態(tài)框效果,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2024-08-08
  • ES6中定義類和對象的方法示例

    ES6中定義類和對象的方法示例

    這篇文章主要介紹了ES6中定義類和對象的方法,結合實例形式分析了ES6中類的定義、繼承、靜態(tài)方法、靜態(tài)屬性等相關操作技巧,需要的朋友可以參考下
    2019-07-07
  • 深入理解JS中的Promise.race控制并發(fā)量

    深入理解JS中的Promise.race控制并發(fā)量

    這篇文章主要為大家介紹了JS中的Promise.race控制并發(fā)量的深入理解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-04-04
  • 通過flv.js播放監(jiān)控示例深入探究直播流技術

    通過flv.js播放監(jiān)控示例深入探究直播流技術

    本文記錄一下在使用 flv.js 播放監(jiān)控視頻時踩過的各種各樣的坑,雖然官網給的?Getting Started?只有短短幾行代碼,跑一個能播視頻的 demo 很容易,但是播放時各種各樣的異常會搞到你懷疑人生,下面我將自己踩過的坑,以及踩坑過程中補充的相關知識,詳細總結一下
    2023-10-10
  • layui復選框的全選與取消實現方法

    layui復選框的全選與取消實現方法

    今天小編就為大家分享一篇layui復選框的全選與取消實現方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09

最新評論