经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » HTML/CSS » HTML5 » 查看文章
HTML5的postMessage的使用手册
来源:jb51  时间:2018/12/20 9:47:14  对本文有异议

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

1、页面内嵌套iframe,与iframe的消息传递

2、页面与多个页面之间的传递消息

针对这些令人头疼的跨域问题,html5特地推出新功能--postMessage(跨文档消息传输)。postMessage在使用时,需要传入2个参数,data和originUrl。data是指需要传递的内容,但是部分浏览器只能处理字符串参数,所以我们一般把data序列化一下,即JSON.stringify(),originUrl是指目标url,指定的窗口。

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

1、页面内嵌套iframe

父页面:

html:

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

js:

  1. window.onload=function(){
  2.  
  3. window.frames[0].postMessage('postMessage','http://127.0.0.1:8082/index2.html')
  4.  
  5. }
  6.  
  7. window.addEventListener('message',function(e){
  8.  
  9. console.log(e)
  10.  
  11. document.getElementById('parent').style.color=e.data
  12.  
  13. })

子页面:

html:

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

js:

  1. window.addEventListener('message',function(e){
  2.  
  3. console.log(e)
  4.  
  5. let color = document.getElementById('button').style.color
  6.  
  7. window.parent.postMessage(color,'http://127.0.0.1:8081/index.html')
  8.  
  9. });
  10.  
  11. function changeColor(){
  12.  
  13. let buttonColor = document.getElementById('button').style.color
  14.  
  15. buttonColor='#f00'
  16.  
  17. window.parent.postMessage(buttonColor,'http://127.0.0.1:8081/index.html')
  18.  
  19. }

父页面通过postMessage的方法向iframe传递消息,而子页面通过window.addEventListener监听message方法来获取到父页面传递的值。如下图所示,data是父页面传递的值。

子页面向父页面传递消息,也是通过postMessage的方法去传递消息,不是过是以window.parent.postMessage(data,url)的方式传值。父页面获取值也是同样监听message事件。

2、多页面之间传递消息

父页面:

html:

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

js:

  1. let parent = document.getElementById('parent')
  2.  
  3. function postMessage(){
  4.  
  5. let windowOpen=window.open('http://127.0.0.1:8082/index2.html','postMessage')
  6.  
  7. setTimeout(function(){
  8.  
  9. windowOpen.postMessage('postMessageData','http://127.0.0.1:8082/index2.html')
  10.  
  11. },1000)
  12.  
  13. }

子页面:

html:

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

js:

  1. window.addEventListener('message',function(e){
  2.  
  3. console.log(e)
  4.  
  5. });

父页面向子页面传递消息通过window.open打开另一个页面,然后向他传值。需要注意的是,使用postMessage传值的时候需要使用setTimeout去延迟消息的传递,因为子页面的加载不是一下子就加载完成的,也就是说子页面的监听事件还未开始,此时传值过去是接收不到的。

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

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号