在iframe怎么把外面的dialog关掉

<template>
<el-dialog ref="dialogRef">
<iframe></iframe>
</el-dialog>
</template>
在iframe怎么把外面的dialog关掉

在 Vue 中,如果要从 iframe 内部关闭外部的 dialog,可以通过在 iframe 中触发父组件的方法来实现。首先,确保你可以访问到父组件的 Vue 实例,然后使用 postMessage() 方法在 iframe 中发送消息给父组件,以通知父组件关闭 dialog

以下是一个示例:

在父组件中:

javascript 复制代码
<template>
  <el-dialog ref="dialogRef">
    <iframe ref="myIframe" src="url_to_your_iframe_content"></iframe>
  </el-dialog>
</template>

<script>
export default {
  methods: {
    closeDialog() {
      // 通过 $refs 获取 el-dialog 组件的引用
      const dialog = this.$refs.dialogRef;
      
      // 调用 el-dialog 的 close 方法
      dialog.close();
    },
    receiveMessage(event) {
      // 接收来自 iframe 的消息
      if (event.data === 'closeDialog') {
        this.closeDialog();
      }
    }
  },
  mounted() {
    // 监听来自 iframe 的消息
    window.addEventListener('message', this.receiveMessage, false);
  },
  beforeDestroy() {
    // 在组件销毁前移除事件监听
    window.removeEventListener('message', this.receiveMessage, false);
  }
}
</script>

在 iframe 内的 JavaScript 中:

javascript 复制代码
// 向父组件发送消息以请求关闭 dialog
function closeParentDialog() {
  window.parent.postMessage('closeDialog', '*');
}

这里的关键是通过 postMessage() 方法向父组件发送消息,在父组件中监听消息并调用关闭 dialog 的方法。记得替换 iframe 中的 src 属性为你实际要加载的内容。

另外一个问题:

closeParentDialog,这个方法中,如果父界面有监听'closeDialog'就window.parent.postMessage('closeDialog', '*');,如果没监听,就调用history.back()

在 iframe 内的 JavaScript 中:

javascript 复制代码
function closeParentDialog() {
  if (window.parent) {
    // 检查是否有父组件监听 'closeDialog' 事件
    const hasListener = window.parent.dispatchEvent(new Event('checkCloseDialog'));

    if (hasListener) {
      // 如果有监听器,向父组件发送消息以请求关闭 dialog
      window.parent.postMessage('closeDialog', '*');
    } else {
      // 如果没有监听器,则执行 history.back()
      window.history.back();
    }
  }
}

在父组件中:

javascript 复制代码
<template>
  <el-dialog ref="dialogRef">
    <iframe ref="myIframe" src="url_to_your_iframe_content"></iframe>
  </el-dialog>
</template>

<script>
export default {
  methods: {
    closeDialog() {
      // 通过 $refs 获取 el-dialog 组件的引用
      const dialog = this.$refs.dialogRef;
      
      // 调用 el-dialog 的 close 方法
      dialog.close();
    },
    receiveMessage(event) {
      // 接收来自 iframe 的消息
      if (event.data === 'closeDialog') {
        this.closeDialog();
      }
    },
    checkCloseDialog() {
      // 检查是否有监听 'closeDialog' 事件
      return this.$listeners.closeDialog !== undefined;
    }
  },
  mounted() {
    // 监听来自 iframe 的消息
    window.addEventListener('message', this.receiveMessage, false);

    // 在父组件中设置事件以供 iframe 检查是否有监听 'closeDialog' 事件
    window.addEventListener('checkCloseDialog', (event) => {
      event.target.dispatchEvent(new Event('checkCloseDialog', { bubbles: true }));
    });
  },
  beforeDestroy() {
    // 在组件销毁前移除事件监听
    window.removeEventListener('message', this.receiveMessage, false);
    window.removeEventListener('checkCloseDialog', () => {});
  }
}
</script>

这样,当 closeParentDialog() 方法在 iframe 中调用时,会首先检查父组件是否有监听 'closeDialog' 事件。如果有监听器,就向父组件发送消息以关闭 dialog;如果没有监听器,就执行 history.back()

相关推荐
毕设十刻15 分钟前
基于Vue的养老服务平台85123(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js
2501_9462447826 分钟前
Flutter & OpenHarmony OA系统下拉刷新组件开发指南
开发语言·javascript·flutter
_Kayo_29 分钟前
React useState setState之后获取到的数据一直是初始值
前端·javascript·react.js
yang9yun38 分钟前
PostMan加载三方JS
javascript·测试工具·postman
Object~43 分钟前
2.变量声明
开发语言·前端·javascript
释怀不想释怀1 小时前
vue前端crud(页面布局,新增,vue中反向代理)
前端·javascript·vue.js
麦麦大数据1 小时前
F068 vue+flask 非遗文化遗产图谱可视化系统
前端·vue.js·flask·知识图谱·文化遗产·非遗文化
QiHY1 小时前
通过Spring Authorization Server对vue应用进行授权防护
java·vue.js·spring·oauth
zpjing~.~1 小时前
iframe和父页面消息通信
开发语言·前端·javascript
老华带你飞1 小时前
电影购票|基于java+ vue电影购票系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot