麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁(yè) > 開發(fā) > HTML5 > 正文

HTML5的postMessage的使用手冊(cè)

2024-09-05 07:22:45
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

我們?cè)诖a代碼的時(shí)候,經(jīng)常會(huì)碰到以下跨域的情況:

1、頁(yè)面內(nèi)嵌套iframe,與iframe的消息傳遞

2、頁(yè)面與多個(gè)頁(yè)面之間的傳遞消息

針對(duì)這些令人頭疼的跨域問題,html5特地推出新功能--postMessage(跨文檔消息傳輸)。postMessage在使用時(shí),需要傳入2個(gè)參數(shù),data和originUrl。data是指需要傳遞的內(nèi)容,但是部分瀏覽器只能處理字符串參數(shù),所以我們一般把data序列化一下,即JSON.stringify(),originUrl是指目標(biāo)url,指定的窗口。

下面直接甩例子,相信大家更容易理解寫。

1、頁(yè)面內(nèi)嵌套iframe

父頁(yè)面:

html:

<div id='parent'>hello word postMessage</div><iframe src="http://127.0.0.1:8082/index2.html" id='child'></iframe>

js:

window.onload=function(){    window.frames[0].postMessage('postMessage','http://127.0.0.1:8082/index2.html')} window.addEventListener('message',function(e){    console.log(e)    document.getElementById('parent').style.color=e.data})

子頁(yè)面:

html:

<div id='button' onclick='changeColor();' style="color:yellow">接受信息</div>

js:

window.addEventListener('message',function(e){      console.log(e)      let color = document.getElementById('button').style.color      window.parent.postMessage(color,'http://127.0.0.1:8081/index.html')});function changeColor(){      let buttonColor = document.getElementById('button').style.color      buttonColor='#f00'                 window.parent.postMessage(buttonColor,'http://127.0.0.1:8081/index.html')}

父頁(yè)面通過(guò)postMessage的方法向iframe傳遞消息,而子頁(yè)面通過(guò)window.addEventListener監(jiān)聽message方法來(lái)獲取到父頁(yè)面?zhèn)鬟f的值。如下圖所示,data是父頁(yè)面?zhèn)鬟f的值。

子頁(yè)面向父頁(yè)面?zhèn)鬟f消息,也是通過(guò)postMessage的方法去傳遞消息,不是過(guò)是以window.parent.postMessage(data,url)的方式傳值。父頁(yè)面獲取值也是同樣監(jiān)聽message事件。

2、多頁(yè)面之間傳遞消息

父頁(yè)面:

html:

<div id='parent' onclick="postMessage()">hello word postMessage</div>

js:

let parent = document.getElementById('parent')function postMessage(){    let windowOpen=window.open('http://127.0.0.1:8082/index2.html','postMessage')    setTimeout(function(){       windowOpen.postMessage('postMessageData','http://127.0.0.1:8082/index2.html')  },1000) }

子頁(yè)面:

html:

<div id='button' onclick='changeColor();' style="color:#f00">接受信息</div>

js:

window.addEventListener('message',function(e){      console.log(e) });

父頁(yè)面向子頁(yè)面?zhèn)鬟f消息通過(guò)window.open打開另一個(gè)頁(yè)面,然后向他傳值。需要注意的是,使用postMessage傳值的時(shí)候需要使用setTimeout去延遲消息的傳遞,因?yàn)樽禹?yè)面的加載不是一下子就加載完成的,也就是說(shuō)子頁(yè)面的監(jiān)聽事件還未開始,此時(shí)傳值過(guò)去是接收不到的。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持武林網(wǎng)。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 国产91对白叫床清晰播放 | 成人在线视频在线观看 | 免费看欧美一级特黄a毛片 九色com | jizzzzxxxxx | av电影在线免费 | 一区二区三区在线视频观看58 | 手机免费看一级片 | 最新一级毛片 | 国产精品一区在线免费观看 | 日韩一级视频 | 亚洲第一视频 | 成人在线视频免费 | 国产精品久久久久久久av三级 | 黄色一级片在线免费观看 | 久久久久久久爱 | 国产一级中文字幕 | av电影直播| 爱操影视 | 欧美日韩免费一区 | 亚洲最新无码中文字幕久久 | 激情宗合网 | 亚洲射逼 | 国产艳妇av视国产精选av一区 | 国产精品一区在线免费观看 | 亚洲午夜免费 | 欧美精品 | 鲁人人人鲁人人鲁精品 | 91嫩草丨国产丨精品入口 | 国产精品爆操 | 久久av免费 | 曰韩av在线 | chinese军人gay呻吟 | 午夜视频观看 | 精品一区在线视频 | 久久久无码精品亚洲日韩按摩 | 久久影片| 成人免费看视频 | 天天夜碰日日摸日日澡性色av | 中文字幕一区2区 | 一及毛片视频 | 精品国产一区三区|