postMessage實現頁面通訊介紹
本章節介紹一下如何實現使用postMessage實現頁面通訊效果。
一.postMessage簡單介紹:
window.postMessage雖然說是html5的功能,但是支援IE8+。
假如網站不需要支援IE6和IE7,那麼可以使用window.postMessage。
window.postMessage是客戶端和客戶端直接的資料傳遞,既可以跨域傳遞,也可以同域傳遞。
二.應用場景:
下面只是一個簡單的例子,當然它的應用場景有很多。
例如有一個頁面,頁面中拿到部分使用者資訊,點選進入另外一個頁面,另外的頁面預設是取不到使用者資訊的,可以通過window.postMessage把部分使用者資訊傳到這個頁面中。(當然要考慮安全性等方面。)
三.程式碼例項:
傳送資訊:
[JavaScript] 純文字檢視 複製程式碼//彈出一個新視窗 var domain = 'http://softwhy.com'; var myPopup = window.open(domain+ '/windowPostMessageListener.html', 'myWindow'); //週期性的傳送訊息 setTimeout(function () { //var message = '當前時間是 ' + (new Date().getTime()); var message = { name: "站點", sex: "男" }; //你在這裡也可以傳遞一些資料,obj等 console.log('傳遞的資料是 ' + message); myPopup.postMessage(message, domain); }, 1000);
要延遲一下,一般用計時器setTimeout延遲再發用。
接受的頁面:
[JavaScript] 純文字檢視 複製程式碼//監聽訊息反饋 window.addEventListener('message', function (event) { //這個判斷一下是不是我這個域名跳轉過來的 if (event.origin !== 'http://softwhy.com') return; console.log('received response: ', event.data); }, false);
如下圖,接受頁面得到資料
如果是使用iframe,程式碼應該這樣寫:
[JavaScript] 純文字檢視 複製程式碼//捕獲iframe var domain = 'http://softwhy.com'; var iframe = document.getElementById('myIFrame').contentWindow; //傳送訊息 setTimeout(function () { //var message = '當前時間是 ' + (new Date().getTime()); var message = { name: "站點", sex: "男" }; //你在這裡也可以傳遞一些資料,obj等 console.log('傳遞的資料是: ' + message); //send the message and target URI iframe.postMessage(message, domain); }, 1000);
接受資料
[JavaScript] 純文字檢視 複製程式碼//響應事件 window.addEventListener('message', function (event) { if (event.origin !== 'http://softwhy.com') return; console.log('message received: ' + event.data, event); event.source.postMessage('holla back youngin!', event.origin); }, false);
上面的程式碼片段是往訊息源反饋資訊,確認訊息已經收到。下面是幾個比較重要的事件屬性:
source – 訊息源,訊息的傳送視窗/iframe。
origin – 訊息源的URI(可能包含協議、域名和埠),用來驗證資料來源。
data – 傳送方傳送給接收方的資料。
相關文章
- sharedWorker 實現多頁面通訊
- 實現兩個視窗通訊方法之postMessage
- 利用Storage Event實現頁面間通訊
- 教你如何實現頁面間的資料通訊
- WPF使用事件聚合器,實現任意頁面跨頁通訊事件
- RabbitMQ的web頁面介紹(三)MQWeb
- 不同頁面通訊與跨域跨域
- OutputStreamWriter介紹&程式碼實現和InputStreamReader介紹&程式碼實現
- Aidl程式間通訊詳細介紹AI
- 網頁被劫持什麼?防止頁面劫持方法介紹網頁
- iframe父子頁面通訊解決方案
- 程式間的五種通訊方式介紹
- 實現不同頁面不同頁首
- 【網路安全】PostMessage:分析JS實現XSSJS
- AWT100無線通訊終端介紹
- 面試官:前端跨頁面通訊,你知道哪些方法?面試前端
- 簡單介紹numpy實現RNN原理實現RNN
- 【Flutter】 介紹一種通用的頁面路由設計方案Flutter路由
- 介紹Cloudflare頁面:構建JAMstack網站的最佳方法Cloud網站
- ASP.NET Core 5.0 MVC中的 Razor 頁面 介紹ASP.NETMVC
- H5頁面實現滑動控制音訊播放H5音訊
- 短視訊程式原始碼,PageSlider實現滑動頁面原始碼IDE
- 網路通訊2:TCP通訊實現TCP
- 如何實現瀏覽器標籤頁之間的通訊瀏覽器
- 程式間的五種通訊方式介紹-詳解
- 第85篇 網路通訊的基礎介紹
- 前端頁面水印生成實現前端
- web頁面錄屏實現Web
- BiLSTM介紹及程式碼實現
- CNN介紹及程式碼實現CNN
- golang實現常用集合原理介紹Golang
- LSM樹的不同實現介紹
- SAP Commerce Cloud OAuth 實現介紹CloudOAuth
- 058、Vue3+TypeScript基礎,頁面通訊之父頁面使用$parent的用法VueTypeScript
- WebRTC – Agora (聲網)簡介與實現音視訊通話WebGo
- 051、Vue3+TypeScript基礎,頁面通訊之v-model在元件中手寫實現VueTypeScript元件
- SAP WebClient UI頁面標籤的決定邏輯介紹WebclientUI
- 關於Webpack5 搭建 React 多頁面應用介紹WebReact
- 匿名管道通訊實現