色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

JavaScript 如何實現(xiàn)同源通信

瀏覽:95日期:2023-09-29 16:47:44
目錄一、Broadcast Channel API 簡介二、Broadcast Channel API 應(yīng)用場景2.1 實現(xiàn)同源頁面間數(shù)據(jù)同步2.2 在其它 Tab 頁面中監(jiān)測用戶操作三、Broadcast Channel API vs postMessage API四、總結(jié)五、參考資源一、Broadcast Channel API 簡介

Broadcast Channel API 可以實現(xiàn)同源下瀏覽器不同窗口、Tab 頁或者 iframe 下的瀏覽器上下文之間的簡單通訊。通過創(chuàng)建一個監(jiān)聽某個頻道下的 BroadcastChannel 對象,你可以接收發(fā)送給該頻道的所有消息。

JavaScript 如何實現(xiàn)同源通信

(圖片來源 —— https://developer.mozilla.org/zh-CN/docs/Web/API/Broadcast_Channel_API)

了解完 Broadcast Channel API 的作用之后,我們來看一下如何使用它:

// 創(chuàng)建一個用于廣播的通信通道const channel = new BroadcastChannel(’my_bus’);// 在my_bus上發(fā)送消息channel.postMessage(’大家好,我是阿寶哥’);// 監(jiān)聽my_bus通道上的消息channel.onmessage = function(e) { console.log(’已收到的消息:’, e.data);};// 關(guān)閉通道channel.close();

通過觀察以上示例,我們可以發(fā)現(xiàn) Broadcast Channel API 使用起來還是很簡單的。該 API 除了支持發(fā)送字符串之外,我們還可以發(fā)送其它對象,比如 Blob、File、ArrayBuffer、Array 等對象。另外,需要注意的是,在實際項目中,我們還要考慮它的兼容性:

JavaScript 如何實現(xiàn)同源通信

(圖片來源 —— https://caniuse.com/?search=Broadcast%20Channel%20API)

由上圖可知,在 IE 11 及以下的版本,是不支持 Broadcast Channel API,這時你就可以考慮使用現(xiàn)成的 broadcast-channel-polyfill 或者基于 localStorage 和 storage 事件來實現(xiàn)。

二、Broadcast Channel API 應(yīng)用場景

利用 Broadcast Channel API,我們可以輕易地實現(xiàn)同源頁面間一對多的通信。該 API 的一些使用場景如下:

實現(xiàn)同源頁面間數(shù)據(jù)同步; 在其它 Tab 頁面中監(jiān)測用戶操作; 指導(dǎo) worker 執(zhí)行一個后臺任務(wù); 知道用戶何時登錄另一個 window/tab 中的帳戶。

為了讓大家能夠更好地掌握 Broadcast Channel API,阿寶哥以前面 2 個使用場景為例,來介紹一下該 API 的具體應(yīng)用。

2.1 實現(xiàn)同源頁面間數(shù)據(jù)同步

html

<h3 id='title'>你好,</h3><input id='userName' placeholder='請輸入你的用戶名' />

JS

const bc = new BroadcastChannel('abao_channel');(() => { const title = document.querySelector('#title'); const userName = document.querySelector('#userName'); const setTitle = (userName) => { title.innerHTML = '你好,' + userName; }; bc.onmessage = (messageEvent) => { if (messageEvent.data === 'update_title') { setTitle(localStorage.getItem('title')); } }; if (localStorage.getItem('title')) { setTitle(localStorage.getItem('title')); } else { setTitle('請告訴我們你的用戶名'); } userName.onchange = (e) => { const inputValue = e.target.value; localStorage.setItem('title', inputValue); setTitle(inputValue); bc.postMessage('update_title'); };})();

在以上示例中,我們實現(xiàn)了同源頁面間的數(shù)據(jù)同步。當(dāng)任何一個已打開的頁面中,輸入框的數(shù)據(jù)發(fā)生變化時,頁面中的 h3#title 元素的內(nèi)容將會自動實現(xiàn)同步更新。

JavaScript 如何實現(xiàn)同源通信

2.2 在其它 Tab 頁面中監(jiān)測用戶操作

利用 Broadcast Channel API,除了可以實現(xiàn)同源頁面間的數(shù)據(jù)同步之外,我們還可以利用它來實現(xiàn)在其它 Tab 頁面中監(jiān)測用戶操作的功能。比如,當(dāng)用戶在任何一個 Tab 中執(zhí)行退出操作后,其它已打開的 Tab 頁面也能夠自動實現(xiàn)退出,從而保證系統(tǒng)的安全性。

html

<h3 id='status'>當(dāng)前狀態(tài):已登錄</h3><button onclick='logout()'>退出</button>

JS

const status = document.querySelector('#status');const logoutChannel = new BroadcastChannel('logout_channel');logoutChannel.onmessage = function (e) { if (e.data.cmd === 'logout') { doLogout(); }};function logout() { doLogout(); logoutChannel.postMessage({ cmd: 'logout', user: '阿寶哥' });}function doLogout() { status.innerText = '當(dāng)前狀態(tài):已退出';}

在以上示例中,當(dāng)用戶點擊退出按鈕后,當(dāng)前頁面會執(zhí)行退出操作,同時會通過 logoutChannel 通知其它已打開的頁面執(zhí)行退出操作。

三、Broadcast Channel API vs postMessage API

與 postMessage() 不同的是,你不再需要維護(hù)對 iframe 或 worker 的引用才能與其進(jìn)行通信:

const popup = window.open(’https://another-origin.com’, ...);popup.postMessage(’Sup popup!’, ’https://another-origin.com’);

Broadcast Channel API 只能用于實現(xiàn)同源下瀏覽器不同窗口、Tab 頁或者 iframe 下的瀏覽器上下文之間的簡單通訊。而 postMessage API 卻可用于實現(xiàn)不同源之間消息通信。由于保證消息來自同一來源,因此無需像以前那樣使用以下方法來驗證消息:

const iframe = document.querySelector(’iframe’);iframe.contentWindow.onmessage = function(e) { if (e.origin !== ’https://expected-origin.com’) { return; } e.source.postMessage(’Ack!’, e.origin);};四、總結(jié)

Broadcast Channel API 是一個非常簡單的 API,內(nèi)部包含了跨上下文通訊的接口。在支持該 API 的瀏覽器中,我們可以利用該 API 輕松地實現(xiàn)同源頁面間的通信。而對于不支持該 API 的瀏覽器來說,我們就可以考慮使用 localStorage 和 storage 事件來解決同源頁面間通信的問題。

五、參考資源

MDN - Broadcast Channel APIBroadcastChannel API: A Message Bus for the Web

以上就是JavaScript 如何實現(xiàn)同源通信的詳細(xì)內(nèi)容,更多關(guān)于JavaScript 同源通信的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 日本一区二区不卡视频 | 成年人黄色免费网站 | 91精品久久久久久久久网影视 | 免费高清在线爱做视频 | 美国一级毛片片aa久久综合 | 99爱在线精品视频免费观看9 | 纯欧美一级毛片免费 | 美女扒开腿让男人桶 | 久久成人免费视频 | 亚洲三级视频在线观看 | 日韩精品视频一区二区三区 | 香蕉依依精品视频在线播放 | 91精品手机国产露脸 | 亚洲第一视频在线观看 | 日本精品视频一区二区三区 | 亚洲精品区 | 欧美日韩一区二区不卡三区 | 欧美xxxx成人免费网站 | 成人a毛片| 欧美日韩一级片在线观看 | 精品国产免费人成在线观看 | 亚洲国产一区二区a毛片日本 | 中文字幕精品一区二区精品 | 日韩一区二区天海翼 | freex性日韩| 欧美aaaa在线观看视频免费 | 欧美极品在线播放 | 亚州人成网在线播放 | 日韩中文字幕网 | 国产主播福利片在线观看 | 欧美人成一本免费观看视频 | 久久精品亚洲精品国产欧美 | 国产成人综合怡春院精品 | 日韩国产中文字幕 | 欧美成人免费观看国产 | 国产午夜精品不卡视频 | 黄色毛片一级 | 亚洲精品人成网线在线 | 国产高清在线精品一区a | 国内成人精品亚洲日本语音 | 欧美精品区 |