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

  • 8
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值