• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    HTML5的postMessage的使用手册

    我们在码代码的时候,经常会碰到以下跨域的情况:

    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去延迟消息的传递,因为子页面的加载不是一下子就加载完成的,也就是说子页面的监听事件还未开始,此时传值过去是接收不到的。

    以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

    上一篇:JavaScript+Canvas实现自定义画板的示例代码
    下一篇:Html5调用手机摄像头并实现人脸识别的实现
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

    HTML5的postMessage的使用手册 HTML5,的,postMessage,使用手册,