JS关闭子窗口并且刷新上一个窗口的实现示例
在开发后台项目的时候产品那边提出了这个一个需求用户点击“选择模板”的时候会弹出一个新窗口,在新窗口选择模板点击确定后,会关闭当前的新窗口,并且原来的那个窗口自动显示用户在新窗口的选择项。
这样会涉及到一个技术点,就是怎么通过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 aessing a cross-origin frame.
不知道是我实现方式有问题还是别的未知原因,没方法,需求在那里,总是需要解决的,经过亲身实践,出了狼蚁网站SEO优化这种可行方法,虽有明显缺点,但也总算了解决了需求。
父界面的代码
<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关闭子窗口内容请搜索狼蚁SEO以前的文章或继续浏览狼蚁网站SEO优化的相关文章希望大家以后多多支持狼蚁SEO!
编程语言
- 宿迁百度关键词排名指南:实现精准营销的关键
- 四川SEO优化怎么做网络推广
- 立昂技术备案老域名收购:如何为您的业务赋能
- 安徽百度关键词seo贵不贵,一般需要多少钱
- 吉林百度快照排名怎么做电话营销
- 多伦新手做SEO怎么做
- 甘肃优化关键词排名推广怎么做论坛营销
- 沙雅SEO网站推广:提升您的在线可见性
- 四川SEO优化如何提升销售额和销售量
- 聂荣网站排名优化:提升网站可见性的全方位指
- 涞水SEO:提升地方企业在线可见性的策略
- 辽宁百度seo排名怎样做网站排名
- 临湘哪有关键词排名优化:提升网站可见度的关
- 黑龙江百度网站优化有没有优惠
- 凉城优化关键词排名推广:提升您的网络可见性
- 萝北整站优化:提升您网站流量和排名的全面指