使用postMesssage()实现iframe跨域页面间的信息传递_javascript技巧
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了使用postMesssage()实现iframe跨域页面间的信息传递_javascript技巧,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2094字,纯文字阅读大概需要3分钟。
内容图文
![使用postMesssage()实现iframe跨域页面间的信息传递_javascript技巧](/upload/InfoBanner/zyjiaocheng/312/6ac8aa7fad0f498d907e2f1c7d0bfe09.jpg)
1. 子页面url传参
简单说来就是把所有需要传递的参数加到与主页面同源的url上,将子页面重定向到该url,然后主页面通过iframe的src获取这些参数
过程非常复杂,不建议使用这种方法
2. postMessage()
postMesssage()是HTML5提供的一个基于事件的消息传输API,可以实现跨文本档、多窗口、跨域消息传递。
postMessage(data,origin)方法接受两个参数
1.data:要传递的数据,html5规范中提到该参数可以是JavaScript的任意基本类型或可复制的对象,然而并不是所有浏览器都做到了这点儿,部分浏览器只能处理字符串参数,所以我们在传递参数的时候需要使用JSON.stringify()方法对对象参数序列化,在低版本IE中引用json2.js可以实现类似效果。
2.origin:字符串参数,指明目标窗口的源,协议+主机+端口号[+URL],URL会被忽略,所以可以不写,这个参数是为了安全考虑,postMessage()方法只会将message传递给指定窗口,当然如果愿意也可以建参数设置为"*",这样可以传递给任意窗口,如果要指定和当前窗口同源的话设置为"/"。
发送消息(子页面)
由于部分浏览器只能处理字符串参数,我们需要先使用JSON.stringfy()将参数转换为字符串,然后再接收页面使用JSON.parse()转换回对象。
接收消息
对于子页面传递过来的参数,我们可以通过监听window的message事件来获取:
message事件有几个重要属性
1.data:顾名思义,是传递来的message
2.source:发送消息的窗口对象
3.origin:发送消息窗口的源(协议+主机+端口号)
通过postMesssage()方法和message事件就可以实现跨域传递消息了,需要注意的是,在demo中我们是通过子页面向父页面传递消息,所以使用的是window.parent发送,window接收:
window.parent.postMessage(dataJson, '*');
如果是从主页面向子页面就需要对换,使用window发送,window.frames[0]来接收了。
以上内容是小编给大家介绍的使用postMesssage()实现iframe跨域页面间的信息传递,希望对大家有所帮助!
内容总结
以上是互联网集市为您收集整理的使用postMesssage()实现iframe跨域页面间的信息传递_javascript技巧全部内容,希望文章能够帮你解决使用postMesssage()实现iframe跨域页面间的信息传递_javascript技巧所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。