JS关闭子窗口并且刷新上一个窗口的实现示例


Posted in Javascript onMarch 10, 2020

在开发后台项目的时候产品那边提出了这个一个需求:用户点击“选择模板”的时候会弹出一个新窗口,在新窗口选择模板点击确定后,会关闭当前的新窗口,并且原来的那个窗口自动显示用户在新窗口的选择项。
这样会涉及到一个技术点,就是怎么通过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关闭子窗口内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
找到一点可怜的关于dojo资料,谢谢作者!
Dec 06 Javascript
使用jQuery轻松实现Ajax的实例代码
Aug 16 Javascript
动态加载图片路径 保持JavaScript控件的相对独立性
Sep 06 Javascript
JavaScript实现拖拽网页内元素的方法
Apr 15 Javascript
javascript 常见功能汇总
Jun 11 Javascript
使用JavaScript实现旋转的彩圈特效
Jun 23 Javascript
前端 Vue.js 和 MVVM 详细介绍
Dec 29 Javascript
vue.js轮播图组件使用方法详解
Jul 03 Javascript
js实现简单模态框实例
Nov 16 Javascript
Vue-cli3.x + axios 跨域方案踩坑指北
Jul 04 Javascript
layui 解决form表单点击无反应的问题
Oct 25 Javascript
浅析我对JS延迟异步脚本的思考
Oct 12 Javascript
Vue动态加载图片在跨域时无法显示的问题及解决方法
Mar 10 #Javascript
Vue项目打包压缩的实现(让页面更快响应)
Mar 10 #Javascript
vue实现瀑布流组件滑动加载更多
Mar 10 #Javascript
JavaScript代理模式原理与用法实例详解
Mar 10 #Javascript
JavaScript命令模式原理与用法实例详解
Mar 10 #Javascript
JavaScript实现指定数量的并发限制的示例代码
Mar 10 #Javascript
vue中的使用token的方法示例
Mar 10 #Javascript
You might like
收音机玩机评测 406 篇视频合集
2020/03/11 无线电
PHP extract 将数组拆分成多个变量的函数
2010/06/30 PHP
thinkPHP模板中函数的使用方法示例
2016/11/30 PHP
基于jquery的横向滚动条(滑动条)
2011/02/24 Javascript
重构Javascript代码示例(重构前后对比)
2013/01/23 Javascript
js超时调用setTimeout和间歇调用setInterval实例分析
2015/01/28 Javascript
js/jquery判断浏览器类型的方法小结
2015/05/12 Javascript
JS简单实现多级Select联动菜单效果代码
2015/09/06 Javascript
jQuery增加和删除表格项目及实现表格项目排序的方法
2016/05/30 Javascript
微信小程序 animation API详解及实例代码
2016/10/08 Javascript
React Native仿美团下拉菜单的实例代码
2017/08/08 Javascript
vue组件生命周期详解
2017/11/07 Javascript
vue组件文档(.md)中如何自动导入示例(.vue)详解
2019/01/25 Javascript
nodejs同步调用获取mysql数据时遇到的大坑
2019/03/02 NodeJs
vue中如何实现后台管理系统的权限控制的方法步骤
2019/09/05 Javascript
Python实现过滤单个Android程序日志脚本分享
2015/01/16 Python
举例讲解Python中字典的合并值相加与异或对比
2016/06/04 Python
详谈pandas中agg函数和apply函数的区别
2018/04/20 Python
使用Python通过win32 COM实现Word文档的写入与保存方法
2018/05/08 Python
Python Scapy随心所欲研究TCP协议栈
2018/11/20 Python
浅谈Python采集网页时正则表达式匹配换行符的问题
2018/12/20 Python
django数据库自动重连的方法实例
2019/07/21 Python
python操作toml文件的示例代码
2020/11/27 Python
白宫黑市官网:White House Black Market
2016/11/17 全球购物
英国电动工具购买网站:Anglia Tool Centre
2017/04/25 全球购物
英国女性时尚精品店:THE DRESSING ROOM
2018/05/23 全球购物
澳大利亚购买健身器材网站:Gym Direct
2019/12/19 全球购物
Wallis官网:英国女装零售商
2020/01/21 全球购物
J2EE是技术还是平台还是框架
2016/08/14 面试题
假日旅行社实习自我鉴定
2013/09/24 职场文书
竞聘副主任科员演讲稿
2014/01/11 职场文书
英语课外活动总结
2014/08/27 职场文书
殡葬服务心得体会
2014/09/11 职场文书
健康状况证明模板
2014/10/23 职场文书
毕业论文致谢信
2015/05/14 职场文书
经济纠纷起诉状
2015/05/20 职场文书