在iframe怎么把外面的dialog关掉

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

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

以下是一个示例:

在父组件中:

<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 中:

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

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

另外一个问题:

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

在 iframe 内的 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();
    }
  }
}

在父组件中:

<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()

相关推荐

  1. iframe怎么外面dialog关掉

    2023-12-19 06:26:04       37 阅读
  2. Vue之iframe标签里刷新外部页面

    2023-12-19 06:26:04       40 阅读

最近更新

  1. TCP协议是安全的吗?

    2023-12-19 06:26:04       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-19 06:26:04       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-19 06:26:04       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-19 06:26:04       20 阅读

热门阅读

  1. IDE:DevEco Studio

    2023-12-19 06:26:04       48 阅读
  2. 每日一练,蓝桥杯

    2023-12-19 06:26:04       51 阅读
  3. serializable和parcelable的区别(GPT回答)

    2023-12-19 06:26:04       39 阅读
  4. 读写分离之同步延迟测试

    2023-12-19 06:26:04       51 阅读
  5. 【mask转json】文件互转

    2023-12-19 06:26:04       53 阅读
  6. Linux 命令大全备忘录

    2023-12-19 06:26:04       47 阅读
  7. 基于三维点云处理技术的工件识别和匹配

    2023-12-19 06:26:04       39 阅读