好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > html5通過postMessage進行跨域通信的方法

html5通過postMessage進行跨域通信的方法

熱門標簽:南寧點撥外呼系統哪家公司做的好 鎮江智能外呼系統有效果嗎 成都智能外呼系統平臺 四川點撥外呼系統 當涂高德地圖標注 電銷機器人電話用什么卡 云南大理400電話申請官方 江蘇智能電銷機器人哪家好 黃島區地圖標注

最近工作中遇到一個需求,場景是:h5頁作為預覽模塊內嵌在pc頁中,用戶在pc頁中能夠做一些操作,然后h5做出響應式變化,達到預覽的效果。

這里首先想到就是把h5頁面用iframe內嵌到pc網頁中,然后pc通過postMessage方法,把變化的數據發送給iframe,iframe內嵌的h5通過addEventListener接收數據,再對數據做響應式的變化。

這里總結一下postMessage的使用,api很簡單:

otherWindow.postMessage(message, targetOrigin, [transfer]);

otherWindow是目標窗口的引用,在當前場景下就是iframe.contentWindow;

message是發送的消息,在Gecko 6.0之前,消息必須是字符串,而之后的版本可以做到直接發送對象而無需自己進行序列化;

targetOrigin表示設定目標窗口的origin,其值可以是字符串"*"(表示無限制)或者一個URI。在發送消息的時候,如果目標窗口的協議、主機地址或端口這三者的任意一項不匹配targetOrigin提供的值,那么消息就不會被發送;只有三者完全匹配,消息才會被發送。對于保密性的數據,設置目標窗口origin非常重要;

當postMessage()被調用的時,一個消息事件就會被分發到目標窗口上。該接口有一個message事件,該事件有幾個重要的屬性:

1.data:顧名思義,是傳遞來的message
2.source:發送消息的窗口對象
3.origin:發送消息窗口的源(協議+主機+端口號)

這樣就可以接收跨域的消息了,我們還可以發送消息回去,方法類似。

可選參數transfer 是一串和message 同時傳遞的 Transferable 對象. 這些對象的所有權將被轉移給消息的接收方,而發送一方將不再保有所有權。

那么,當iframe初始化后,可以通過下面代碼獲取到iframe的引用并發送消息:

// 注意這里不是要獲取iframe的dom引用,而是iframe window的引用
const iframe = document.getElementById('myIFrame').contentWindow;
iframe.postMessage('hello world', 'http://yourhost.com');

在iframe中,通過下面代碼即可接收到消息。

window.addEventListener('message', msgHandler, false);

在接收時,可以根據需要,對消息來源origin做一下過濾,避免接收到非法域名的消息導致的xss攻擊。

最后,為了代碼復用,把消息發送和接收封裝成一個類,同時模擬了消息類型的api,使用起來非常方便。具體代碼如下:

export default class Messager {
    constructor(win, targetOrigin) {
        this.win = win;
        this.targetOrigin = targetOrigin;
        this.actions = {};
        window.addEventListener('message', this.handleMessageListener, false);
    }

    handleMessageListener = event => {
        if (!event.data || !event.data.type) {
            return;
        }
        const type = event.data.type;
        if (!this.actions[type]) {
            return console.warn(`${type}: missing listener`);
        }
        this.actions[type](event.data.value);
    }

    on = (type, cb) => {
        this.actions[type] = cb;
        return this;
    }

    emit = (type, value) => {
        this.win.postMessage({
            type, value
        }, this.targetOrigin);
        return this;
    }

    destroy() {
        window.removeEventListener('message', this.handleMessageListener);
    }
}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

標簽:十堰 咸寧 西寧 南京 淮安 佳木斯 酒泉 廣西

巨人網絡通訊聲明:本文標題《html5通過postMessage進行跨域通信的方法》,本文關鍵詞  html5,通過,postMessage,進行,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《html5通過postMessage進行跨域通信的方法》相關的同類信息!
  • 本頁收集關于html5通過postMessage進行跨域通信的方法的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 成人国产精品毛片| x8x8x8女性性爽免费视频在线观看| 欧美精品一区二区在线观看播放| 男男又爽?又黄?免费韩国| 看黄免费app| 婢女奶咪子真大高h| 警察好大?好爽?湿透了| 石阡县| 男人女人性视频| 一级黄色一级片| 热热色影音先锋| 免费高清无遮挡床震视频| 韩国护士xxxx视频| 凹厕所xxxxbbbb偷拍视频| 鲤鱼乡扶腰猛烈顶撞bl| 好吊操免费视频| 91久久精品美女高潮喷水动漫 | 玩弄极品少妇高潮抽搐电影| 日韩精品一区二区三区免费观看 | 国内精品久久久久影院优| 天干天干啦夜天干天2019| 调教羞辱跪下宿舍女虐女| 岳对准着粗大坐了下去| 性欧美孕妇孕交XXOO| 女给男囗交姿势图3d效果展示图| 国产又大又长又粗又硬爽| 美女很黄很黄免费的| 300一晚同城约茶| 强行挺进白丝老师里呻吟| 天天拍久久| 久久xxxx| 欧美高清videosex极品| 亚洲 校园 都市 自拍 在线| 爽?好大?快?深点陆深| 免费看男人吃奶摸捏奶头视频| 国产图片综合区| 桃色交易| 高h辣文肉| 国产精品午夜激爽毛片| 久久久久久久精品无码少妇mv| 51精品国产人成在线观看 |