记录:用window.open打开的页面如何进行数据交互?

场景: 在一个新增物资的页面上,我要点击按钮,执行 window.open()打开人员录入的工单。在人员工单上,我要填写完信息,点击提交按钮,就会产生一个人员申请的id出来。在提交完以后,我想要这个人员申请的id传到新增物资的页面上来。

解决方案:

使用 window.open() 打开新页面,这意味创建了一个完全独立的浏览器窗口/标签页,与原页面是两个独立的文档环境。

这两个页面的通信方式如下:

方案一:使用 postMessage API(推荐)

这是跨窗口通信的标准方式:

javascript 复制代码
javascript
// 在原页面打开新窗口时
const newWindow = window.open(`/page/tickets/visitor/new`, '_blank');
// 监听来自新窗口的消息
window.addEventListener('message', (event) => {
  // 验证消息来源(安全考虑)
  if (event.origin !== window.location.origin) return;
  
  if (event.data.type === 'PERSON_CREATED') {
    const { id } = event.data.payload;
    // 更新页面上的 ID 显示
    setId(id);
  }
});

// 在新页面提交成功后
// window.opener 指向打开当前窗口的窗口
window.opener.postMessage({
  type: 'PERSON_CREATED',
  payload: { id: newPersonId }
}, window.location.origin);

// 关闭当前窗口
window.close();

方案二:使用 localStorage + 轮询(适用于不能修改新页面的情况)

javascript 复制代码
javascript
// 在原页面中
const newWindow = window.open(`/page/tickets/visitor/new`, '_blank');

// 轮询检查 localStorage 中是否有新创建的 ID
const checkForNewId = setInterval(() => {
  const newPersonData = localStorage.getItem('newPersonCreated');
  if (newPersonData) {
    const { id } = JSON.parse(newPersonData);
    setId(id);
    localStorage.removeItem('newPersonCreated');
    clearInterval(checkForNewId);
  }
}, 1000);

// 在新页面提交成功后
localStorage.setItem('newPersonCreated', JSON.stringify({ id: newPersonId }));
window.close();

方案三:URL 参数传递 + 页面刷新监听

javascript 复制代码
javascript
// 在原页面中
const newWindow = window.open(`/page/tickets/visitor/new`, '_blank');

// 监听新窗口关闭事件
const checkWindowClosed = setInterval(() => {
  if (newWindow.closed) {
    // 检查是否创建了新人员
    const newPersonId = sessionStorage.getItem('newPersonId');
    if (newPersonId) {
      setId(newPersonId);
      sessionStorage.removeItem('newPersonId');
    }
    clearInterval(checkWindowClosed);
  }
}, 500);

// 在新页面提交成功后
sessionStorage.setItem('newPersonId', newPersonId);
window.close();

对于跨窗口通信场景,我最推荐使用方案一(postMessage API) ,因为:

  1. 它是现代浏览器提供的标准跨窗口通信方式
  2. 安全性更好(可以验证消息来源)
  3. 实时性更强(不需要轮询)
  4. 符合 Web API 的最佳实践

根据你项目的情况和安全要求,选择最适合的方案即可。

相关推荐
广州华水科技7 小时前
单北斗变形监测一体机在基础设施安全与地质灾害监测中的应用价值分析
前端
钟智强7 小时前
React2Shell:CVE-2025-66478 Next.js 远程执行漏洞深度分析与代码剖析
开发语言·javascript·ecmascript
Dragon Wu7 小时前
Electron Forge集成React Typescript完整步骤
前端·javascript·react.js·typescript·electron·reactjs
芳草萋萋鹦鹉洲哦7 小时前
【Tailwind】动画解读:Tailwind CSS Animation Examples
前端·css
华仔啊7 小时前
jQuery 4.0 发布,IE 终于被放弃了
前端·javascript
一心赚狗粮的宇叔7 小时前
03.Node.js依赖包补充说明及React&Node.Js项目
前端·react.js·node.js
子春一7 小时前
Flutter for OpenHarmony:音律尺 - 基于Flutter的Web友好型节拍器开发与节奏可视化实现
前端·flutter
JarvanMo7 小时前
150万开发者“被偷家”!这两款浓眉大眼的 VS Code 插件竟然是间谍
前端
亿元程序员7 小时前
大佬,现在AI游戏开发教程那么多,你不搞点卖给大学生吗?
前端
未来龙皇小蓝7 小时前
RBAC前端架构-02:集成Vue Router、Vuex和Axios实现基本认证实现
前端·vue.js·架构