首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >火狐中丢失的window.opener引用

火狐中丢失的window.opener引用
EN

Stack Overflow用户
提问于 2022-02-17 08:18:28
回答 1查看 146关注 0票数 5

考虑以下情况:

  • 步骤1:网站A在一个新的选项卡中打开网站B(此时,网站B有其打开窗口引用,即window.opener中的网站A窗口对象)。
  • 第二步:网站B重定向到网站C(我们有window.opener参考网站A窗口在这里)。
  • 步骤3:然后,网站C执行一些身份验证并重定向到网站B。在本步骤3中,window.opener具有当前窗口对象的引用,即网站B本身的窗口对象(window.opener ===窗口),并且我们失去了对原始打开器(即网站A窗口对象)的引用。我们需要使用window.opener对象与网站A使用postMessage进行通信。

步骤的可视化汇辑

注意:我们无法控制网站C,也无法控制它们如何重定向到网站B。而且,这只发生在Firefox/Safari上。在Chrome上,我们能够在重定向之后获得原始的开线器参考。

如果网站C正在用rel=noopener重定向,则window.opener应该为null (来自MDN的参考)。我无法理解在这种情况下,window.opener可以是当前的窗口对象,以及为什么它发生在Firefox/Safari上,而不是在Chrome上?除了网站C,我们还能做些什么来防止这种情况发生吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-02-17 17:12:59

这在火狐和Safari中是可能的,当您添加目标_self时,_self可以是当前窗口。如果您执行window.open('someurl', '_self'),那么window.opener将是当前窗口,并将在相同的选项卡中打开,而不是在新的选项卡中打开。这种情况只发生在safari和firefox中(据我观察到)。在任何情况下,所有基于铬的浏览器都不会更改原来的开窗器。

我不知道safari和firefox以这种方式处理它的确切原因,我试图找出原因,但找不到。

我曾经面对过这个问题,我们做过的解决方案是让网站C使用window.location.replacewindow.location.href重定向回网站B,这样他们就在同一个选项卡中打开了网站b。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/71154547

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档