JS实现iframe中子父页面跨域通讯的方法分析


Posted in Javascript onMarch 10, 2020

本文实例讲述了JS实现iframe中子父页面跨域通讯的方法。分享给大家供大家参考,具体如下:

在非跨域的情况下,iframe中的子父页面可以很方便的通讯,但是在跨域的情况下,只能通过window.postMessage()方法来向其他页面发送信息,其他页面要通过window.addEventListener()监听事件来接收信息;

#跨域发送信息

#window.postMessage()语法

otherWindow.postMessage(message, targetOrigin, [transfer]);
  • otherWindow
    其他窗口的一个引用,写的是你要通信的window对象。
    例如:在iframe中向父窗口传递数据时,可以写成window.parent.postMessage(),window.parent表示父窗口。
  • message
    需要传递的数据,字符串或者对象都可以。
  • targetOrigin
    表示目标窗口的源,协议+域名+端口号,如果设置为“*”,则表示可以传递给任意窗口。在发送消息的时候,如果目标窗口的协议、域名或端口这三者的任意一项不匹配targetOrigin提供的值,那么消息就不会被发送;只有三者完全匹配,消息才会被发送。例如:
    window.parent.postMessage('hello world','http://xxx.com:8080/index.html')
    只有父窗口是http://xxx.com:8080时才会接受到传递的消息。

  • [transfer]
    可选参数。是一串和message 同时传递的 Transferable 对象,这些对象的所有权将被转移给消息的接收方,而发送一方将不再保有所有权。我们一般很少用到。

#跨域接收信息

需要监听的事件名为"message"

window.addEventListener('message', function (e) {
  console.log(e.data) //e.data为传递过来的数据
  console.log(e.origin) //e.origin为调用 postMessage 时消息发送方窗口的 origin(域名、协议和端口)
  console.log(e.source) //e.source为对发送消息的窗口对象的引用,可以使用此来在具有不同origin的两个窗口之间建立双向通信
})

#示例Demo

示例功能:跨域情况下,子父页面互发信息并接收。

  • 父页面代码:
<body>
  <button onClick="sendInfo()">向子窗口发送消息</button>
  <iframe id="sonIframe" src="http://192.168.2.235/son.html"></iframe>
  <script type="text/javascript">

    var info = {
      message: "Hello Son!"
    };
    //发送跨域信息
    function sendInfo(){
      var sonIframe= document.getElementById("sonIframe");
      sonIframe.contentWindow.postMessage(info, '*');
    }
    //接收跨域信息
    window.addEventListener('message', function(e){
        alert(e.data.message);
    }, false);
  </script>
</body>
  • 子页面代码
<body>
  <button onClick="sendInfo()">向父窗口发送消息</button>
  <script type="text/javascript">

    var info = {
      message: "Hello Parent!"
    };
    //发送跨域信息
    function sendInfo(){
      window.parent.postMessage(info, '*');
    }
    //接收跨域信息
    window.addEventListener('message', function(e){
        alert(e.data.message);
    }, false);
  </script>
</body>

感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.3water.com/code/HtmlJsRun测试上述代码运行效果。

更多关于JavaScript相关内容可查看本站专题:《JavaScript操作DOM技巧总结》、《JavaScript页面元素操作技巧总结》、《JavaScript事件相关操作与技巧大全》、《JavaScript查找算法技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript错误与调试技巧总结》

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
javascript parseInt 函数分析(转)
Mar 21 Javascript
跟着JQuery API学Jquery 之三 筛选
Apr 09 Javascript
在次封装easyui-Dialog插件实现代码
Nov 14 Javascript
firefox下input type=&quot;file&quot;的size是多大
Oct 24 Javascript
JavaScript中的类数组对象介绍
Dec 30 Javascript
ECMAScript中函数function类型
Jun 03 Javascript
JS实现iframe编辑器光标位置插入内容的方法(兼容IE和Firefox)
Jun 24 Javascript
Bootstrap 表单验证formValidation 实现表单动态验证功能
May 17 Javascript
vue.js删除动态绑定的radio的指定项
Jun 02 Javascript
JavaScript之Canvas_动力节点Java学院整理
Jul 04 Javascript
了解重排与重绘
May 29 Javascript
layui使用数据表格实现购物车功能
Jul 26 Javascript
详解vue-template-admin三级路由无法缓存的解决方案
Mar 10 #Javascript
JS Html转义和反转义(html编码和解码)的实现与使用方法总结
Mar 10 #Javascript
js模拟实现烟花特效
Mar 10 #Javascript
JS实现放烟花效果
Mar 10 #Javascript
JS实现烟花爆炸效果
Mar 10 #Javascript
JS Web Flex弹性盒子模型代码实例
Mar 10 #Javascript
JS实现网页烟花动画效果
Mar 10 #Javascript
You might like
PHP日期时间函数的高级应用技巧
2009/05/16 PHP
将酷狗krc歌词解析并转换为lrc歌词php源码
2014/06/20 PHP
PHP编写daemon process详解及实例代码
2016/09/30 PHP
利用Homestead快速运行一个Laravel项目的方法详解
2017/11/14 PHP
jquery 单击li防止重复加载的实现代码
2010/12/24 Javascript
javascript判断网页是关闭还是刷新
2015/09/12 Javascript
jQuery中inArray方法注意事项分析
2016/01/25 Javascript
window.onload绑定多个事件的两种解决方案
2016/05/15 Javascript
原生JS封装ajax 传json,str,excel文件上传提交表单(推荐)
2016/06/21 Javascript
jQuery调用Webservice传递json数组的方法
2016/08/06 Javascript
js仿腾讯QQ的web登陆界面
2016/08/19 Javascript
javascript如何创建对象
2016/08/29 Javascript
微信小程序 教程之小程序配置
2016/10/17 Javascript
JavaScript日期工具类DateUtils定义与用法示例
2018/09/03 Javascript
d3绘制基本的柱形图的实现代码
2018/12/12 Javascript
Vue2.x Todo之自定义指令实现自动聚焦的方法
2019/01/08 Javascript
优雅的将ElementUI表格变身成树形表格的方法步骤
2019/04/11 Javascript
nodejs+koa2 实现模仿springMVC框架
2020/10/21 NodeJs
[02:05]2014DOTA2西雅图邀请赛 专访啸天mik夫妻档
2014/07/08 DOTA
[02:42]完美大师赛主赛事淘汰赛第三日观众采访
2017/11/25 DOTA
[41:52]2018DOTA2亚洲邀请赛3月29日 小组赛A组 TNC VS OpTic
2018/03/30 DOTA
Python实现删除文件但保留指定文件
2015/06/21 Python
Python中的条件判断语句基础学习教程
2016/02/07 Python
python验证码识别教程之利用投影法、连通域法分割图片
2018/06/04 Python
django 环境变量配置过程详解
2019/08/06 Python
python 操作hive pyhs2方式
2019/12/21 Python
Windows下PyCharm配置Anaconda环境(超详细教程)
2020/07/31 Python
Airbnb爱彼迎官网:成为爱彼迎房东,赚取收入
2019/03/14 全球购物
初中数学教学反思
2014/01/16 职场文书
11月红领巾广播稿
2014/01/17 职场文书
大学理论知识学习自我鉴定
2014/04/28 职场文书
建筑横幅标语
2014/10/09 职场文书
六查六看自检自查剖析材料
2014/10/14 职场文书
关于国庆节的广播稿
2015/08/19 职场文书
2019通用版劳动合同范本!
2019/07/11 职场文书
MySQL优化常用的19种有效方法(推荐!)
2022/03/17 MySQL