iframe传参问题

方法一:postmessage

传参数

子向父页面传参

window.parent.postMessage({ // 参数是对象
    DOCK_ID: ship.userData.dockId,
}, '*');

父向子页面传参

在这里插入图片描述

写法一 window.frames
// 点击触发传参
// 多个参数传参写法1
window.frames[0].postMessage({ dataa: data.dataa}, '*');
window.frames[0].postMessage({ datab: data.datab}, '*');
// 多个参数传参写法2
window.frames[0].postMessage({ 
	dataa: data.dataa,
	datab: data.datab,
}, '*');
写法二 contentWindow

父组件HTML写上ref 或者id 或者classname

<div>
	<iframe src = 'http://localhost:8080' ref = 'iframeref' id= 'iframeid' class = 'iframeclass'/>
</div>
const iframe = this.$refs.iframeref;
// const iframe = document.getElementById('iframeid');
// const iframe = document.getElementByClassName('iframeclass');

iframe.contentWindow.postMessage({
	id: data.id,
	name: data.name,
}, '*');

接受参数
在这里插入图片描述
父子页面监听消息接收都是

 window.addEventListener('message', (event) => {
   console.log(event.data)
 }, false);

方法二 doument.domain 主域相同的场景

父页面访问子页面:

// 通过contentWindow访问子域名挂载在window上的状态管理器
window.iframes[0].contentWindow.vm.$store.state

子页面访问父页面:

// 通过contentWindow访问子域名挂载在window上的状态管理器
window.parent.vm.$store.state
  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
帆软报表可以通过使用iframe传递参数来实现灵活的数据展示和筛选功能。 首先,在页面中创建一个iframe元素,并设置其src属性为帆软报表的地址。同时,可以使用query参数的方式向报表传递参数。例如,可以在src属性的值后面添加问号("?")符号,并用键值对的形式添加参数,例如src="http://example.com/report.html?param1=value1&param2=value2"。 接下来,在页面的JavaScript代码中,可以通过获取iframe元素的contentWindow属性来访问其内部的文档对象,进而操作报表。通过contentWindow对象,可以使用JavaScript动态地修改报表中的参数值,实现不同条件下的数据展示和筛选。 例如,可以使用以下代码获取iframe元素并设置参数值: var iframe = document.getElementById("reportFrame"); iframe.contentWindow.document.getElementById("param1").value = "new value"; 以上代码中,reportFrame是iframe元素的id,param1是报表中一个参数的id,可以使用getElementById方法获取。然后,将参数的值设置为新值,以更新报表展示内容。 此外,还可以通过JavaScript监听iframe元素的加载完成事件,以确保在报表加载完成后再设置参数值。例如,可以使用以下代码: iframe.onload = function() { iframe.contentWindow.document.getElementById("param1").value = "new value"; }; 通过以上方式,可以实现通过iframe传递参数给帆软报表并实现灵活的数据展示和筛选功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值