VUE组件和IFRAME页面的相互传参问题

VUE组件和IFRAME页面的相互传参问题
标签: vue

VUE组件和IFRAME页面的相互传参问题
目前网上大多关于iframe父子传参的博客都是在叙述父页面是html文件,子iframe文件也是html文件,涉及到父页面是vue组件子iframe页面是html的博客多数讲的不是很明白;

而最近我在项目中碰到了这种需求:在vue组件中嵌入iframe页面,并实现父子传参;

VUE组件调用IFRAME页面方法和参数
下面是在 vue组件中(父组件) 一个通过点击按钮触发的方法:

sentToIframe() {
let childFrameObj = document.getElementById(“unityiframe”);
console.log(“childFrameObj”, childFrameObj);
// childFrameObj.contentWindow.getMessageFromParent(this.tData); //第一种向子iFrame传参方式,调用iframe的methods达到传参的目的
this.$refs.unity.contentWindow.getMessageFromParent(this.tData); // 这样也是可以调用子iframe的方法

  // childFrameObj.contentWindow.frameData = "这是vue组件给你的参数!" // 传参成功
  this.$refs.unity.contentWindow.frameData =
    "这是vue组件给你的第二个参数!"; //传参成功
  console.log("发送完成");

  //此外,还可以通过DOM操作,操作子iframe的DOM
  var t = document
    .getElementById("unityiframe")
    .contentWindow.document.getElementById("dd");
  console.log(t);
  //
  console.log("frameData?", unityiframe.window.frameData); //利用id可以调用到iframe里的变量
  // console.log("frameData?",this.$refs.unity.window.frameData) //利用ref调用不到iframe里的变量
},

子组件 iframe页面 中有一个被调用的方法及变量:

var frameData = “别喊我!” //此变量用于测试 vue组件是否能调用此变量
function getMessageFromParent(value){
// 接受从vue组件中传过来的参数
console.log(我接收到parent传过来的参数了:${value})
}

点击按钮的结果是:
在这里插入图片描述

IFRAME页面向VUE组件传参
在vue组件中有一个供iframe页面调用的方法:

getFromIframe(value) {
  console.log(`我是iframe传过来的参数:${value}`);
  console.log("我被iframe调用了!");
  console.log(this.vueData);
  console.log(`改变前是:你是否能够改变我;改变后是:${this.isChangeMe}`);
}

iframe调用vue组件方法的代码:

function Obj(res){
// Obj通过按钮点击触发
console.log(parent)
// 调用vue组件方法
parent.getFromIframe(“我叫iframe”)
// 向vue组件发送参数 && 改变vue组件的参数
parent.isChangeMe = “你已经被我iframe改变了”
}

但是 !!!!!!!!!!!!!!!

只这么做是不够的,会报错,如下:
在这里插入图片描述
个人猜想: 问题的原因是 iframe的parent并不是vue实例!

目前只找到了一个办法来解决这个问题:

就是在created钩子里加上这两句,

created() {
window.getFromIframe = this.getFromIframe; //把vue实例中的方法引用给window对象
},

在调用的vue实例的方法中 加上对vue内变量的改变

getFromIframe(value) {
  console.log(`我是iframe传过来的参数:${value}`);
  console.log("我被iframe调用了!");
  console.log(this.vueData);
  this.isChangeMe = window.isChangeMe;// 把window变量 赋值给 vue 实例变量;使得在iframe中能够改变vue实例中变量
  console.log(`改变前是:你是否能够改变我;改变后是:${this.isChangeMe}`);
}

最终的运行结果是:
在这里插入图片描述
bingo!!!!! 问题暂时得到了解决。

总结
vue组件 和 iframe 的嵌入麻烦多多,且目前还没还没找到正统的方法;此外,还有很多坑我还没踩到,如果后续这方面有什么问题 以及 其他的解决方案,我 会继续更新到这上面来的!

如果各位有什么好的解决办法,欢迎指教!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值