位置: 编程技术 - 正文

使用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闭包解决了什么问题)

  • 免租期租金怎么处理
  • 累计减税费用是什么意思
  • 个税超过部分征税还是全部
  • 出纳人员去银行提取现金时应填写现金缴款单
  • 金税三期国地税合并
  • 信用卡产生滞纳金
  • 将自制的一批新产品用于对外投资,生产成本为300000
  • 广告制作需要缴纳文化事业建设税吗?
  • 优化技巧
  • 开通税种需要带发票吗
  • 企业筹办期多久
  • 核销外管证需要什么手续
  • 受托加工物资产生的成本怎么做会计核算?
  • 应收款项核销的原因
  • u盘如何进行杀毒
  • virtualbox打不开虚拟机
  • 固定资产更新改造支出资本化
  • clipbrd.exe是什么意思
  • mce文件是什么软件
  • 企业管理的管理系统
  • 账面价值大于计税基础为啥为递延所得税负债
  • vue-plugin-hiprint vue hiprint vue使用hiprint打印控件VUE HiPrint HiPrint简单使用
  • 20分钟,使用Amazon SageMaker快速搭建属于自己的AIGC应用
  • js中this指向有几种情况
  • -shared
  • 以小物件为话题写出背后的故事
  • 预缴2%
  • 销售自己使用过的物品的税率
  • 发票错开退税款什么时候退回
  • 会计制度备案附件要上传什么
  • 收到的免税苗木发票必须当月抵扣么
  • java线程的四种基本状态
  • 计提工资后面附什么
  • 学习笔记——Servlet
  • 小规模纳税人的条件
  • 工资薪金的税务筹划
  • 或有资产的确认条件基本确定
  • 应该免税的增值税是什么
  • 预收账款挂账多长时间必须确认收入
  • 出纳属于会计岗位职责吗
  • 失控发票多久能查出
  • 建行e信通贴现高不高
  • 查账征收个体户经营所得税怎么计算
  • 分期收款发出商品一批,售价50000
  • 购买商品加包装怎么入账
  • 两个企业同一个法人
  • 低预算高要求
  • 一个工程项目多个业主吗
  • 盘亏的固定资产是资产吗
  • 律师事务所如何成立
  • 淘宝电商怎么做账
  • 营业外收入计入哪里
  • 什么是电子商业承兑汇票贴现
  • 已提折旧是什么意思
  • SQL直接操作excel表(查询/导入/插入)
  • sql 随机
  • vic32.dll是什么
  • win8固态硬盘
  • ubuntu的sudo
  • linux系统进程管理
  • win10不兼容游戏名单
  • Linux下OpenVPN配置静态密钥(static-key)验证教程
  • android开发环境搭建实验报告总结
  • mmap实现原理
  • excle纵坐标
  • Windows环境下搭建Python开发环境的方法
  • 持久化存储数据的方式
  • 使用jquery实现的项目
  • jquery常用api
  • js面向对象编程思想
  • python怎么多进程
  • unity3d怎么用
  • js定义类的三种方法
  • 如何用nodejs搭建服务端
  • python socketcan
  • jqgrid分页pager
  • 河北发票查询真伪查询
  • 安徽省工商总局
  • 江苏电子税务局网站官网
  • 扬州国家税务学院在哪个区
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设