在开发后台项目的时候产品那边提出了这个一个需求:用户点击“选择模板”的时候会弹出一个新窗口,在新窗口选择模板点击确定后,会关闭当前的新窗口,并且原来的那个窗口自动显示用户在新窗口的选择项。
这样会涉及到一个技术点,就是怎么通过JS来实现关闭子窗口并且刷新上一个窗口。
百度了很久,尝试了以下几种方案:
方案一:通过在子窗口的关闭函数中加入以下代码,即可实现父窗口的刷新。
window.opener.location.href = window.opener.location.href;
方案二:也是在子窗口的关闭函数中加入以下代码:
function closeMeAndReloadParent(){ opener.location.reload(); window.close(); }
以及方案三window.opener.location.reload();
方案四window.opener.reload();等等
结果发现以上方案全都不行,且都会报以下这种错误:
scrollbymyself.html:96 Uncaught DOMException: Blocked a frame with origin "null" from accessing a cross-origin frame.
不知道是我实现方式有问题还是别的未知原因,没方法,需求在那里,总是需要解决的,经过亲身实践,总结出了下面这种可行方法,虽有明显缺点,但也总算了解决了需求。
父界面的代码
<span onclick="openNewWindow()">点击打开新窗口</span> <input type="text" class="parent-input"> <script> function openNewWindow() { document.querySelector(".parent-input").focus() window.open("scrollbymyself.html", "new window"); } document.querySelector(".parent-input").onfocus = function () { console.log("获取到了焦点,可以在这里写逻辑代码") } console.log("页面重新刷新") </script>
子界面的代码
<span onclick="closeCurrentWindow()">点击关闭当前窗口,并且更新上一个窗口的信息</span> <script> function closeCurrentWindow() { console.log(window) opener.location.reload(); window.close() } </script>
把上面的代码应该到项目中,即可实现需求,如果不想让input显示在界面上,可以添加opacity: 0;样式属性。
注意:
添加display: none;属性的话,并不会触发input的获取焦点的事件函数。
到此这篇关于JS关闭子窗口并且刷新上一个窗口的实现示例的文章就介绍到这了,更多相关JS关闭子窗口内容请搜索小牛知识库以前的文章或继续浏览下面的相关文章希望大家以后多多支持小牛知识库!
本文向大家介绍c# 实现子窗口关闭父窗口也关闭的方法,包括了c# 实现子窗口关闭父窗口也关闭的方法的使用技巧和注意事项,需要的朋友参考一下 其实是窗口间通讯的问题,在form1上打开form2 ,form2 关闭时关闭form1 实现方法: 在子窗口form2中声明事件: 然后在它的关闭事件中触发本事件: 在父窗口form1中(比如登陆窗口中): 然后弹出子form2窗体的地方这样写: 以上这篇c
问题内容: 我通过window.open打开了一个弹出窗口。使用JavaScript打开,我想在关闭此弹出窗口时刷新父页面。(onclose事件?)我该怎么办? 问题答案: 您可以使用“ window.opener”访问父窗口,因此,在子窗口中编写如下内容:
本文向大家介绍vuejs中监听窗口关闭和窗口刷新事件的方法,包括了vuejs中监听窗口关闭和窗口刷新事件的方法的使用技巧和注意事项,需要的朋友参考一下 1、使用window.onunload之类的API 2、在生命周期钩子中注册监听事件 在 mounted 钩子中注册事件 在 destroyed 钩子卸载事件 以上这篇vuejs中监听窗口关闭和窗口刷新事件的方法就是小编分享给大家的全部内容了,希望
本文向大家介绍C#实现关闭子窗口而不释放子窗口对象的方法,包括了C#实现关闭子窗口而不释放子窗口对象的方法的使用技巧和注意事项,需要的朋友参考一下 在线扫描相机的调试过程中,需要开辟调试界面来进行位置的配置。调试结束后,一种常用的方式是将调试参数保存并在下次启动时加载。另一种简单方式是直接使用该参数运行程序。因此,在后一种情况下,需要实现的功能是:即使关闭调试窗口,其窗口对象也不释放。除非其主窗口
微信扫码登录,在主窗口弹出一个小窗口进行登录,如下图: 扫码授权登录成功之后,如何关闭这个小窗口,并且自动刷新大窗口,更新session。 目前我做的是,打开了这个小窗口,但是扫码登录之后,跳转到的新页面显示在了小窗口中。
本文向大家介绍函数window.open实现关闭所有的子窗口,包括了函数window.open实现关闭所有的子窗口的使用技巧和注意事项,需要的朋友参考一下 此文介绍了如何用window.open方法打开一个子窗口,当我们要关闭主窗口时,这时候所有的子窗口也会跟着关闭。下面有我的实现思路和代码,分享给大家。 实现思路: 1.打开子窗口函数window.open(url,winName)的第二个参数w