vue之组件和iframe页面的相互传参问题

 更新时间:2025年06月12日 09:08:56   作者:阿飞920  
这篇文章主要介绍了vue之组件和iframe页面的相互传参问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

目前网上大多关于iframe父子传参的博客都是在叙述父页面是html文件,子iframe文件也是html文件,涉及到父页面是vue组件子iframe页面是html的博客多数讲的不是很明白;而最近我在项目中碰到了这种需求:在vue组件中嵌入iframe页面,并实现父子传参;

1.vue组件调用iframe页面方法和参数

(1-1)下面是在 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里的变量
    },

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

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

点击按钮的结果是:

2.iframe页面向vue组件传参

(2-1)在vue组件中有一个供iframe页面调用的方法:

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

(2-2)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 的嵌入麻烦多多,且目前还没还没找到正统的方法;此外,还有很多坑我还没踩到,如果后续这方面有什么问题 以及 其他的解决方案,我会继续更新到这上面来的!

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • vue.js 实现v-model与{{}}指令方法

    vue.js 实现v-model与{{}}指令方法

    这篇文章主要介绍了vue.js 实现v-model与{{}}指令方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-10-10
  • vue3使用自定义指令实现el dialog拖拽功能示例详解

    vue3使用自定义指令实现el dialog拖拽功能示例详解

    这篇文章主要为大家介绍了vue3使用自定义指令实现el dialog拖拽功能示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-09-09
  • vue3数据监听watch/watchEffect的示例代码

    vue3数据监听watch/watchEffect的示例代码

    我们都知道监听器的作用是在每次响应式状态发生变化时触发,在组合式 API 中,我们可以使用 watch()函数和watchEffect()函数,下面我们来看下vue3如何进行数据监听watch/watchEffect,感兴趣的朋友一起看看吧
    2023-02-02
  • vue3响应式对象的api超全实例详解

    vue3响应式对象的api超全实例详解

    可以把数据变成响应式api的方法叫做响应式api,下面这篇文章主要给大家介绍了关于vue3响应式对象api的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-05-05
  • vue的template模板是如何转为render函数的过程

    vue的template模板是如何转为render函数的过程

    Vue从template到render函数的转换经历模板解析、AST构建、优化、生成渲染函数等步骤,首先进行词法分析将模板拆解为tokens,再进行语法分析构建AST,然后对AST进行静态标记和提升优化,最后转换成JavaScript渲染函数,生成虚拟DOM,完成组件的渲染和更新,实现了模板的高效转化
    2024-10-10
  • vue组件开发之slider组件使用详解

    vue组件开发之slider组件使用详解

    这篇文章主要为大家详细介绍了vue组件开发之slider组件的使用方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-08-08
  • 解决el-menu标题过长显示不全问题

    解决el-menu标题过长显示不全问题

    本文主要介绍了如何解决el-menu标题过长显示不全问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,感兴趣的朋友们跟着小编来一起学习学习吧
    2023-12-12
  • 深入解析Vue的自定义指令

    深入解析Vue的自定义指令

    这篇文章主要介绍了深入解析Vue的自定义指令,自定义指令主要是为了重用涉及普通元素的底层 DOM 访问的逻辑,一个自定义指令由一个包含类似组件生命周期钩子的对象来定义,需要的朋友可以参考下
    2023-05-05
  • vue3使用vuedraggable实现拖拽功能

    vue3使用vuedraggable实现拖拽功能

    这篇文章主要为大家详细介绍了vue3使用vuedraggable实现拖拽功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-04-04
  • Vue.js一个文件对应一个组件实践

    Vue.js一个文件对应一个组件实践

    Vue.js实现"一个文件对应一个组件",无需webpack等工具,按需加载组件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-10-10

最新评论