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

主頁 > 知識庫 > HTML5的postMessage的使用手冊

HTML5的postMessage的使用手冊

熱門標簽:地圖標注軟件打印出來 欣鼎電銷機器人 效果 電話機器人技術 黃石ai電銷機器人呼叫中心 惡搞電話機器人 ok電銷機器人 高德地圖標注商戶怎么標 智能電銷機器人被禁用了么 如何查看地圖標注

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

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是父頁面傳遞的值。

子頁面向父頁面傳遞消息,也是通過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的使用手冊》,本文關鍵詞  HTML5,的,postMessage,使用手冊,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《HTML5的postMessage的使用手冊》相關的同類信息!
  • 本頁收集關于HTML5的postMessage的使用手冊的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 六月色| 久久宗合伊人永久精品| 乱l高辣h文bl校园| 情趣欧美秘书办公室激情| 亚洲免费中文字幕| 欧美喷潮久久久XXXXx| 韩国av| 免费人成网站7777视频| 男人边做边摸下面视频| 免费?无码?国产在线观看午夜| 黄色小说网页| 日本桃色电影| www干| 艳妇肉欲高潮呻吟1—6| 迷奷绝色年轻女教师| 色网777| 日产精品一二三四区国产| 两性色视频| 男的j进女的p动态图片| 羽月希被同事榨乳电影| 日本特黄特色大片免费播放视频| 国产精品喷潮抽搐无码动漫| 欧美久久久久久精品免费免费直播| 欧美啪视频| 兄弟在线观看免费版| 露脸极品xvideos| 日韩免费一区二区三区在线| 久久精品亚洲AV无码毛笔的| 欧美亚洲综合卡通另类区| 妻子中字高清| sxx在线观看| 国精一二二产品无人区网站| 亚洲精品秘?一区二区三区影院忠贞 | 全黄H全肉边做边吃奶视频| 娇喘求饶激烈进入| 极致凌虐被迫高潮sm在线观看| 国产福利一区二区三区四区 | 日本特级aⅴ一级毛片| 性欧美??潮喷水色欲小说| 美女隐私网站视频| 免费小说阅读|