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

首頁 > 編程 > HTML > 正文

HTML5的postMessage的使用手冊

2024-08-26 00:21:13
字體:
來源:轉載
供稿:網友

我們在碼代碼的時候,經常會碰到以下跨域的情況:

1、頁面內嵌套iframe,與iframe的消息傳遞

2、頁面與多個頁面之間的傳遞消息

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

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

1、頁面內嵌套iframe

父頁面:

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})

子頁面:

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')}

父頁面通過postMessage的方法向iframe傳遞消息,而子頁面通過window.addEventListener監聽message方法來獲取到父頁面傳遞的值。如下圖所示,data是父頁面傳遞的值。

HTML5,postMessage,使用手冊

子頁面向父頁面傳遞消息,也是通過postMessage的方法去傳遞消息,不是過是以window.parent.postMessage(data,url)的方式傳值。父頁面獲取值也是同樣監聽message事件。

2、多頁面之間傳遞消息

父頁面:

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) }

子頁面:

html:

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

js:

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

父頁面向子頁面傳遞消息通過window.open打開另一個頁面,然后向他傳值。需要注意的是,使用postMessage傳值的時候需要使用setTimeout去延遲消息的傳遞,因為子頁面的加載不是一下子就加載完成的,也就是說子頁面的監聽事件還未開始,此時傳值過去是接收不到的。

HTML5,postMessage,使用手冊

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


注:相關教程知識閱讀請移步到HTML教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 狠狠久久 | 亚洲成人欧美在线 | 石原莉奈日韩一区二区三区 | 热99精品视频 | 黄色电影免费网址 | 日本一区二区在线看 | 在线成人一区二区 | 久久精品久久久久 | 国产中出在线观看 | 国产精品成人一区二区三区吃奶 | 国产在线精品一区二区 | 久久精品片 | 国产毛片自拍 | 国产精品免费观在线 | 成人精品视频网站 | 欧美日韩国产成人在线观看 | 亚洲综合无码一区二区 | 91精品国产综合久久久动漫日韩 | 免费在线观看成年人视频 | 欧美a∨一区二区三区久久黄 | 亚洲成年人免费网站 | 成人免费网站在线观看视频 | 色骚综合 | 一级片999| 天天鲁在线视频免费观看 | 免费一级毛片在线播放不收费 | 在线观看视频毛片 | 88xx成人精品视频 | 女人久久久www免费人成看片 | 九九热视频免费在线观看 | 成品片a免人视频 | 黄在线免费 | 九九热色 | 久久99精品久久久久久久久久久久 | 一级毛片在线观看视频 | 最新午夜综合福利视频 | 久久草草影视免费网 | 露脸各种姿势啪啪的清纯美女 | 欧洲黄视频 | 亚洲黑人在线观看 | 欧美不卡 |