位置: 编程技术 - 正文

使用postMesssage()实现iframe跨域页面间的信息传递(使用权资产)

编辑:rootadmin

推荐整理分享使用postMesssage()实现iframe跨域页面间的信息传递(使用权资产),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:使用灭火器时要对准火焰的什么部位喷射,使用粗盐热敷十大危害,使用的英文,使用的英文,使用粗盐热敷十大危害,使用灭火器时要对准火焰的什么部位喷射,使用的拼音,使用时间,内容如对您有帮助,希望把文章链接给更多的朋友!

由于web同源策略的限制,当页面使用跨域iframe链接时,主页面与子页面是无法交互的,这对页面间的信息传递造成了不小的麻烦,经过一系列的尝试,最后我发现有以下方法可以实现:

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传递给指定窗口,当然如果愿意也可以建参数设置为"*",这样可以传递给任意窗口,如果要指定和当前窗口同源的话设置为"/"。

发送消息(子页面)

使用postMesssage()实现iframe跨域页面间的信息传递(使用权资产)

由于部分浏览器只能处理字符串参数,我们需要先使用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跨域页面间的信息传递,希望对大家有所帮助!

分析js闭包引起的事件注册问题 背景:闲暇时间看了几篇关于js作用域链与闭包的文章,偶然又看到了之前遇到的一个问题,就是在for循环中为dom节点注册事件驱动,具体见下面代码:

javascript中不易分清的slice,splice和split三个函数 每每见到这三个函数,我都会很懵,一定要到网上搜搜;今天,恰巧又见到了它们,所以想必是时候为它们做个笔记啦1.slice(数组)用法:array.slice(star

js解决movebox移动问题 本文为大家分享了js解决movebox移动问题,并且取消图片默认拖动事件的相关操作,供大家参考,具体内容如下html:!DOCTYPEhtmlhtmlheadmetahttp-equiv="Content-Type"co

标签: 使用权资产

本文链接地址:https://www.jiuchutong.com/biancheng/375984.html 转载请保留说明!

上一篇:JavaScript面向对象程序设计教程(javascript面向对象编程指南)

下一篇:分析js闭包引起的事件注册问题(js闭包解决了什么问题)

  • 进项税额比销项税额多怎么填申报表
  • 公司房产税如何
  • 住宿普通发票怎么做账
  • 固定资产清理的账务处理
  • 邀请客户参加公司会议
  • 外购自用需要缴纳增值税吗
  • 贴现利息可以抵扣吗
  • 服务行业营业成本包括财务费用和管理费用吗
  • 营改增后小规模纳税人所得税
  • 年金计算个税需要扣除吗
  • 在建工程预付款项记入什么会计科目
  • 报刊杂志广告文案写作
  • 内蒙古地税电子税务局app
  • 发票认证系统查不到发票
  • 两个立项可以并在一起招标吗
  • 发票和实际业务发生时间不一致
  • 高速公路通行费抵扣最新规定
  • 产假期间出现事故可以报工伤吗
  • 注册资本多少钱算大公司
  • 1697509200
  • 有限合伙人的投资风险有哪些
  • 暂估入库有时间限制吗
  • 开票收入怎么理解
  • 公益性捐赠包括向脱贫地区捐赠吗
  • 给对方发短信显示imessage
  • win11打开设置
  • 现金流量表怎么编制
  • 在linux中使用什么命令可以动态查看文件内容
  • 汇算清缴申报表怎么填
  • python安装tensorflow gpu
  • ctrl起什么作用
  • 净资产收益率怎么求
  • css flaot
  • 利润表本月数可以不填吗
  • php 断点续传
  • vscode怎么看错误提示
  • 待抵扣进项税计入其他应收款
  • 出售债券的税费会计分录
  • 出口增值税免抵退税
  • 发票违法行为的认定
  • 股东分红缴税期限
  • 信用减值损失的借贷方向
  • 织梦怎么调用当前栏目下的文章
  • 上季度忘记申报个税了
  • linux大版本升级
  • 净利润和盈余公式的关系
  • 融资租赁缴纳什么税
  • 代开增值税额与实际缴款额差一分钱如何入账?
  • 跨月发票作废如何恢复
  • 法定盈余公积和任意盈余公积可用于
  • 财务费用为什么是向债权人支付的现金流量
  • 风险纳税人去税务局去报税可以吗
  • 农产品免税收入需要缴纳所得税吗
  • 印花税计提金额怎么算
  • 困难补助属于兜底政策吗
  • 公司收到赔偿款要交增值税吗
  • 加计扣除声明怎么填
  • sql集合包含关系
  • 用union怎么把结果加起来
  • 如何使用一键启动
  • lsm.exe是什么程序
  • WIN7系统电脑对话框跟鼠标走怎样设置
  • win7打开网页显示证书有问题
  • mac os 必装软件
  • spring中aop实现
  • python win
  • jquery cookie存取
  • android自定义组件开发详解
  • python中__init__
  • linux的python
  • 曲剧全场戏双玉蝉
  • python django运行
  • jquery技巧
  • android app安全
  • js实现跨域访问的几种方式
  • 合肥税务局招聘信息
  • 成都所见所得科技有限公司是什么平台
  • 福建地方税务局招聘
  • 江苏 税务局
  • 城市维护建设税减半征收政策
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设