在开发后台项目的时候产品那边提出了这个一个需求:用户点击”选择模板”的时候会弹出一个新窗口,在新窗口选择模板点击确定后,会关闭当前的新窗口,并且原来的那个窗口自动显示用户在新窗口的选择项。
这样会涉及到一个技术点,就是怎么通过JS来实现关闭子窗口并且刷新上一个窗口。
百度了很久,尝试了以下几种方案:
方案一:通过在子窗口的关闭函数中加入以下代码,即可实现父窗口的刷新。
window.opener.location。href=https://www.yisu.com/zixun/window.opener.location.href;
方案二:也是在子窗口的关闭函数中加入以下代码:
函数closeMeAndReloadParent () { opener.location.reload (); window.close (); } >之前以及方案三window.opener.location.reload ();
方案四window.opener.reload();等等
结果发现以上方案全都不行,且都会报以下这种错误:
scrollbymyself。html: 96未捕获DOMException:阻塞一个框架与起源的“零”访问跨源框架。
引用>
不知道是我实现方式有问题还是别的未知原因,没方法,需求在那里,总是需要解决的,经过亲身实践,总结出了下面这种可行方法,虽有明显缺点,但也总算了解决了需求。
父界面的代码
& lt; span>点击打开新窗口& lt;/span> & lt;输入类型=拔谋尽眂lass=皃arent-input”比; & lt; script> 函数openNewWindow () { document.querySelector (“.parent-input”) .focus () window.open (“scrollbymyself。html”、“新窗口”); } document.querySelector (“.parent-input”)。得到焦点=function () { console.log(“获取到了焦点,可以在这里写逻辑代码”) } console.log(“页面重新刷新”) & lt;/script> >之前子界面的代码
& lt; span>点击关闭当前窗口,并且更新上一个窗口的信息& lt;/span> & lt; script> 函数closeCurrentWindow () { console.log(窗口) opener.location.reload (); window.close () } & lt;/script> >之前把上面的代码应该到项目中,即可实现需求,如果不想让输入显示在界面上,可以添加不透明度:0;样式属性。
注意:
添加显示:没有,属性的话,并不会触发输入的获取焦点的事件函数。
到此这篇关于JS关闭子窗口并且刷新上一个窗口的实现示例的文章就介绍到这了,更多相关JS关闭子窗口内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
JS关闭子窗口并且刷新上一个窗口的实现示例