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

JavaScript使用Broadcast?Channel實(shí)現(xiàn)前端跨標(biāo)簽頁(yè)通信

 更新時(shí)間:2024年04月22日 08:19:54   作者:MerkleJqueryRu  
這篇文章主要為大家詳細(xì)介紹了JavaScript如何使用Broadcast?Channel實(shí)現(xiàn)前端跨標(biāo)簽頁(yè)通信,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下

在開(kāi)發(fā)Web應(yīng)用程序時(shí),有時(shí)候需要在不同的瀏覽器標(biāo)簽頁(yè)之間進(jìn)行通信。例如,你可能需要在一個(gè)標(biāo)簽頁(yè)中做出的更改在另一個(gè)標(biāo)簽頁(yè)中反映出來(lái),或者需要在用戶在一個(gè)標(biāo)簽頁(yè)中執(zhí)行某些操作時(shí)向其他標(biāo)簽頁(yè)發(fā)送消息。為了實(shí)現(xiàn)這樣的跨標(biāo)簽頁(yè)通信,我們可以借助HTML5提供的Broadcast Channel API。

實(shí)現(xiàn)步驟

首先,我們需要?jiǎng)?chuàng)建兩個(gè)文件:一個(gè)HTML文件和一個(gè)JavaScript文件。

HTML文件:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script type="text/javascript" src="./crossTabMsg.js"></script>
</head>
<body>
    <button id="btn">發(fā)送消息</button>
    <script type="text/javascript">
        var btn = document.getElementById('btn');
        btn.onclick = function() {
            sendMsg('test', 'hello');
        }
        listenMsg(function(msg) {
            console.log(msg);
        })
    </script>
</body>
</html>

JavaScript文件(crossTabMsg.js):

const channel = new BroadcastChannel('cross-tab-msg');

function sendMsg(type, msg) {
    channel.postMessage({type, msg});
}

function listenMsg(callback) {
    channel.addEventListener('message', e => {
        callback && callback(e.data);
    });
}

在HTML文件中,我們創(chuàng)建了一個(gè)按鈕,并為其添加了一個(gè)點(diǎn)擊事件處理程序。當(dāng)用戶點(diǎn)擊按鈕時(shí),我們調(diào)用sendMsg函數(shù)發(fā)送一條消息。同時(shí),我們也調(diào)用listenMsg函數(shù)來(lái)監(jiān)聽(tīng)來(lái)自其他標(biāo)簽頁(yè)的消息,并在控制臺(tái)中打印出來(lái)。

在JavaScript文件中,我們創(chuàng)建了一個(gè)名為cross-tab-msg的新的Broadcast Channel,并定義了兩個(gè)函數(shù):sendMsg用于發(fā)送消息,listenMsg用于監(jiān)聽(tīng)消息。當(dāng)收到消息時(shí),listenMsg函數(shù)會(huì)觸發(fā)回調(diào)函數(shù),并將接收到的消息作為參數(shù)傳遞給回調(diào)函數(shù)。

使用方法

要在不同的標(biāo)簽頁(yè)之間進(jìn)行通信,只需在這些標(biāo)簽頁(yè)中加載相同的HTML和JavaScript文件即可。當(dāng)你在一個(gè)標(biāo)簽頁(yè)中點(diǎn)擊按鈕發(fā)送消息時(shí),其他標(biāo)簽頁(yè)中的監(jiān)聽(tīng)器將會(huì)接收到這條消息,并執(zhí)行相應(yīng)的操作。

結(jié)論

通過(guò)使用Broadcast Channel API,我們可以輕松地實(shí)現(xiàn)跨標(biāo)簽頁(yè)通信,使得不同標(biāo)簽頁(yè)之間可以方便地進(jìn)行消息傳遞和數(shù)據(jù)共享。這為開(kāi)發(fā)復(fù)雜的Web應(yīng)用程序提供了更多的可能性和靈活性。

方法補(bǔ)充

除了上文的方法,小編還為大家整理了其他JavaScript跨標(biāo)簽頁(yè)通信的方法,希望對(duì)大家有所幫助

1.localstorage

<!-- 1.html -->
<script>
  if(!localStorage.getItem('a')){
		localStorage.setItem('a',1)
	}else{
		var sum = localStorage.getItem('a')
		localStorage.setItem('a', +sum + 1)
	}
</script>

<!-- 2.html  -->
<script>
  window.addEventListener('storage', (e) => console.log(e))
</script>
sessionStorage.setItem('message', '我是sessionStorage的值');
// 觸發(fā)自定義事件來(lái)通知其他標(biāo)簽頁(yè)
var event = new Event('sessionStorageUpdated');
window.dispatchEvent(event);
 
window.addEventListener('storage', function(event) {
  if (event.key === 'message') {
    var message = sessionStorage.getItem('message');
    console.log('message:', message);
  }
});
 
// 監(jiān)聽(tīng)自定義事件來(lái)檢測(cè) `sessionStorage` 的更新
window.addEventListener('sessionStorageUpdated', function() {
  var message = sessionStorage.getItem('message');
  console.log('message:', message);
});

2.postMessage

<!-- 1.html -->
<body>
    <button class="pop">彈出新窗口</button>
    <button class="button">發(fā)送數(shù)據(jù)</button>
    <script>
      const pop = document.querySelector('.pop');
      const button = document.querySelector('.button');

      let index = 0;
      let opener = null;

      pop.addEventListener('click', () => {
        opener = window.open(
          '2.html',
          '123',
          'height=600,width=600,top=20,resizeable=yes'
        );
      });

      button.addEventListener('click', () => {
        const data = {
          value: `moment ${index++}`,
        };

        opener.postMessage(data, '*');
      });
    </script>
  </body>

  <!-- 2.html -->
  <body>
  <div>postMessage  2.html</div>
  <script>
    window.addEventListener("message", (e) => {
      console.log(e.data);
    });
  </script>
</body>

3.SharedWorker

<!-- a.html -->
<script>
  let index = 0;
  const worker = new SharedWorker("worker.js");

  setInterval(() => {
    worker.port.postMessage(`moment ${index++}`);
  }, 1000);
</script>

<!-- b.html -->
<script>
  const worker = new SharedWorker("worker.js");

  worker.port.start();
  setInterval(() => {
    worker.port.postMessage("php是世界上最好的語(yǔ)言");
  }, 1000);

  worker.port.onmessage = function (e) {
    if (e.data) {
      console.log(e.data);
    }
  };
</script>

創(chuàng)建一個(gè) worker.js 文件,并編寫(xiě)以下代碼:

let data = "";

self.onconnect = (e) => {
  const port = e.ports[0];

  port.onmessage = function (e) {
    if (e.data === "php是世界上最好的語(yǔ)言") {
      port.postMessage(data);
      data = "";
    } else {
      data = e.data;
    }
  };
};

到此這篇關(guān)于JavaScript使用Broadcast Channel實(shí)現(xiàn)前端跨標(biāo)簽頁(yè)通信的文章就介紹到這了,更多相關(guān)JavaScript Broadcast Channel跨標(biāo)簽頁(yè)通信內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • js去除重復(fù)字符串兩種實(shí)現(xiàn)方法

    js去除重復(fù)字符串兩種實(shí)現(xiàn)方法

    js去除重復(fù)字符串在項(xiàng)目開(kāi)發(fā)中很實(shí)用,接下來(lái)詳細(xì)介紹實(shí)現(xiàn)方法,感興趣的朋友可以參考下
    2013-01-01
  • 淺析webpack 如何優(yōu)雅的使用tree-shaking(搖樹(shù)優(yōu)化)

    淺析webpack 如何優(yōu)雅的使用tree-shaking(搖樹(shù)優(yōu)化)

    這篇文章主要介紹了webpack 如何使用tree-shaking(搖樹(shù)優(yōu)化),本文介紹了什么是tree-shaking,commonJS 模塊,es6 模塊,怎么使用tree-shaking等,具體操作步驟大家可查看下文的詳細(xì)講解,感興趣的小伙伴們可以參考一下。
    2017-08-08
  • 獲取當(dāng)前按鈕或者h(yuǎn)tml的ID名稱實(shí)例(推薦)

    獲取當(dāng)前按鈕或者h(yuǎn)tml的ID名稱實(shí)例(推薦)

    下面小編就為大家?guī)?lái)一篇獲取當(dāng)前按鈕或者h(yuǎn)tml的ID名稱實(shí)例(推薦)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-06-06
  • Ajax 加載數(shù)據(jù) 練習(xí)代碼

    Ajax 加載數(shù)據(jù) 練習(xí)代碼

    這篇文章主要介紹了Ajax 加載數(shù)據(jù),主要是為了查詢表的顯示,不用嵌入php通過(guò)ajax調(diào)用,現(xiàn)在手機(jī)端的更多顯示功能都是通過(guò)ajax實(shí)現(xiàn)的
    2017-01-01
  • javascript淘寶主圖放大鏡功能

    javascript淘寶主圖放大鏡功能

    這篇文章主要為大家詳細(xì)介紹了javascript淘寶主圖放大鏡功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-10-10
  • div層的移動(dòng)及性能優(yōu)化

    div層的移動(dòng)及性能優(yōu)化

    層的移動(dòng)本來(lái)很簡(jiǎn)單,用jquery插件或者自己寫(xiě)一個(gè)也不難,但是最近一個(gè)ipad項(xiàng)目里,發(fā)現(xiàn)用手移動(dòng)div會(huì)感覺(jué)很卡,體驗(yàn)很差(可能是ipad的配置根不上pc)。
    2010-11-11
  • 兩種JS實(shí)現(xiàn)屏蔽鼠標(biāo)右鍵的方法

    兩種JS實(shí)現(xiàn)屏蔽鼠標(biāo)右鍵的方法

    這篇文章主要介紹了兩種JS實(shí)現(xiàn)屏蔽鼠標(biāo)右鍵的方法,瀏覽者在訪問(wèn)你網(wǎng)頁(yè)的時(shí)候就不能點(diǎn)擊右鍵,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2015-08-08
  • JS基于正則實(shí)現(xiàn)數(shù)字千分位用逗號(hào)分隔的方法

    JS基于正則實(shí)現(xiàn)數(shù)字千分位用逗號(hào)分隔的方法

    這篇文章主要介紹了JS基于正則實(shí)現(xiàn)數(shù)字千分位用逗號(hào)分隔的方法,涉及javascript正則表達(dá)式操作數(shù)字的相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2017-06-06
  • javascript DOM操作之動(dòng)態(tài)刪除TABLE多行

    javascript DOM操作之動(dòng)態(tài)刪除TABLE多行

    DOM動(dòng)態(tài)刪除TABLE tr行的實(shí)現(xiàn)代碼,需要的朋友可以參考下。
    2009-12-12
  • JavaScript使用Promise實(shí)現(xiàn)并發(fā)請(qǐng)求數(shù)限制

    JavaScript使用Promise實(shí)現(xiàn)并發(fā)請(qǐng)求數(shù)限制

    本文主要介紹了JavaScript使用Promise實(shí)現(xiàn)并發(fā)請(qǐng)求數(shù)限制,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-04-04

最新評(píng)論