postMessage使用

前情 在项目中需要新开一个窗口页面

在项目中需要新开一个窗口页面展示富文本编辑器,富文本编辑器内容编辑完成关闭新窗口,旧页面需要重新调用接口

这里想到使用postMessage进行跨窗口通信 postMessage (window.postMessage - Web API | MDN)

window.postMessage() 方法可以安全地实现跨源通信。通常,对于两个不同页面的脚本,只有当执行它们的页面位于具有相同的协议(通常为 https),端口号(443 为 https 的默认值),以及主机 (两个页面的模数 Document.domain设置为相同的值) 时,这两个脚本才能相互通信。window.postMessage() 方法提供了一种受控机制来规避此限制,只要正确的使用,这种方法就很安全。 引入文档内容 介绍

上一级文件使用

ts 复制代码
let msgPage: Window | null = null
function handleEditor() {
  msgPage = window.open(
    router.resolve({
      name: 'xxx',
    }).href,
    '_blank'
  )
  msgPage && msgPage.postMessage('show editor', '*')
}
window.addEventListener('message', (e) => {
  if (e.data === 'editor close') {
    //富文本编辑器关闭了 调用需要的
  }
})

富文本文件

ts 复制代码
//新窗口打开
const start = () => {
  opener && opener.postMessage('editor open')
}
start()
//新窗口关闭
opener && opener.postMessage('editor close')
window.close()
if (!window.closed) {
  alert('请手动关闭本标签页')
}
相关推荐
饼饼饼6 分钟前
React19 新手指南:JSX 没那么难,用好这几条规则就够了
前端·javascript·react.js
想吃火锅10056 分钟前
【前端手撕】new
前端
小小小小宇13 分钟前
AI大背景下端到端界面测试
前端
小小小小宇21 分钟前
前端端到端界面测试全解析与应用
前端
去伪存真25 分钟前
如何将没有字幕的英文视频转换成中文视频?
前端·pytorch·llm
Coisinier32 分钟前
RHCE中shell脚本基础(磁盘剩余空间监控,Web 服务状态检查,curl 访问 Web 服务并返回状态)
linux·运维·服务器·前端·nginx·操作系统
ywl4708120871 小时前
springSecurity+jwt,简单版demo
java·前端·servlet
想吃火锅10051 小时前
【前端手撕】promise.all
前端
lichenyang4531 小时前
动态加载 vs 延迟加载:为什么 demo 里「延迟」看起来没效果?
前端
cypking1 小时前
从零搭建 Claude Code + Chrome MCP 浏览器自动化:前端 E2E 端到端测试完整教程(包含增量测试)
前端·chrome·自动化