JavaScript使用window.open打开的页面进行数据交互的三种方案

 更新时间:2025年10月17日 10:47:42   作者:snow来了  
本文主要介绍了在通过 window.open 打开新页面后,如何实现与原页面的数据交互,主要推荐使用 postMessage API 进行跨窗口通信,同时还提供了 localStorage+轮询和URL参数传递等备选方案,并分析了各自优缺点,需要的朋友可以参考下

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

解决方案:

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

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

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

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

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
// 在原页面中
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
// 在原页面中
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 的最佳实践

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

到此这篇关于JavaScript使用window.open打开的页面进行数据交互的三种方案的文章就介绍到这了,更多相关JavaScript window.open页面进行数据交互内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • JS显示表格内指定行html代码的方法

    JS显示表格内指定行html代码的方法

    这篇文章主要介绍了JS显示表格内指定行html代码的方法,涉及javascript获取行及innerHTML属性的使用技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-03-03
  • JS实现仿新浪黄色经典滑动门效果代码

    JS实现仿新浪黄色经典滑动门效果代码

    这篇文章主要介绍了JS实现仿新浪黄色经典滑动门效果代码,是一款非常简单的经典鼠标响应滑动切换效果,涉及JavaScript基于鼠标事件动态操作页面元素的技巧,需要的朋友可以参考下
    2015-09-09
  • next.js初始化参数设置getServerSideProps应用学习

    next.js初始化参数设置getServerSideProps应用学习

    这篇文章主要为大家介绍了next.js初始化参数设置getServerSideProps的应用示例学习,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • js实现的倒计时按钮实例

    js实现的倒计时按钮实例

    这篇文章主要介绍了js实现的倒计时按钮,实例分析了javascript倒计时效果的相关实现技巧,需要的朋友可以参考下
    2015-06-06
  • JavaScript数据结构之单链表和循环链表

    JavaScript数据结构之单链表和循环链表

    这篇文章主要介绍了JavaScript数据结构之单链表、循环链表,详细的介绍了JavaScript如何实现单链表、循环链表,有兴趣的可以了解一下
    2017-11-11
  • ES6新特性二:Iterator(遍历器)和for-of循环详解

    ES6新特性二:Iterator(遍历器)和for-of循环详解

    这篇文章主要介绍了ES6新特性二:Iterator(遍历器)和for-of循环,结合实例形式分析了ES6中Iterator(遍历器)和for-of循环遍历操作的相关实现技巧与注意事项,需要的朋友可以参考下
    2017-04-04
  • js new Date()实例测试

    js new Date()实例测试

    在本篇文章中小编给各位整理的是关于js new Date()测试的相关实例代码,有需要的朋友们参考学习下。
    2019-10-10
  • Javascript图像处理—平滑处理实现原理

    Javascript图像处理—平滑处理实现原理

    这里直接引用OpenCV 2.4+ C++ 平滑处理和OpenCV 2.4+ C++ 边缘梯度计算的相关内容平滑也称模糊, 是一项简单且使用频率很高的图像处理方法,需要了解的朋友可以参考下
    2012-12-12
  • Stop SQL Server

    Stop SQL Server

    Stop SQL Server...
    2007-06-06
  • js中事件绑定addEventListener()和attachEvent()的区别

    js中事件绑定addEventListener()和attachEvent()的区别

    本文主要介绍了js中事件绑定addEventListener()和attachEvent()的区别,前者支持多函数绑定且顺序执行,后者IE兼容但顺序相反,下面就来详细的介绍一下,感兴趣的可以了解一下
    2025-05-05

最新评论