众所周知,在vue中bus等工具只能跨 组件通信 ,如何实现跨窗口通信呢?
场景如下,我们在A窗口中新开了B窗口,想在B窗口中调用A窗口的方法?
这里还总结了 一点 window事件的方法:
window.o PE ner.location.reload() &nbs p; 这样关闭B窗口后会刷新整个A窗口,体验效果不是很好
window.onunload 在关闭窗口之后触发
window.opener 获取父页面的window元素
注:
1.window.opener 实际上就是通过window.open()打开的窗体的父窗体
2.window.opener.父页面中的方法();//调用父页面中的方法
location.reload() 刷新页面
window.close() 关闭window.open()打开的窗口
window.onbeforeunload 关闭窗口前执行事件
A窗口:
mount ed() { // 注:getBpageList是提供给新窗口B触发的,实际上触发的是A的getApageList方法 window["getBpageList"] = (par am s) => { this.getApageLists(params); }; methods: { async getApageLists(){ let res = aw ai t getPageList() .. .... }, //点击新打开一个窗口B detailsView(data) { window.open(`....${data.id}`); }, }
b窗口调用A窗口方法
注:具体场景可以很多,比如放在 点击事件 中, 或者 关闭窗口前等 methods:{ em IT Awindow(){ //window.opener 获取父页面的window元素 //判断A窗口有没有window.opener和getBpageList是不是个方法 if (window.opener && window.opener.getBpageList) { window.opener.getBpageList(params); } else { //window.opener.frames[0] 获取到的window对象 window.opener.frames[0].getBpageList(params); } } }
总结
到此这篇关于vue跨窗口通信之新窗口调用父窗口的 文章 就介绍到这了,更多相关vue新窗口调用父窗口内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
您可能感兴趣的文章: Vue全家桶入门基础教程 Vue全家桶实践项目总结(推荐) 一篇Vue、React重点详解大全 vue项目刷新当前页面的三种方式(重载当前页面数据) vue通过url方式展示PDF的几种方法 vue全家桶-vuex深入讲解
总结
以上是 为你收集整理的 vue跨窗口通信之新窗口调用父窗口方法实例 全部内容,希望文章能够帮你解决 vue跨窗口通信之新窗口调用父窗口方法实例 所遇到的问题。
如果觉得 网站内容还不错, 推荐好友。
查看更多关于vue跨窗口通信之新窗口调用父窗口方法实例的详细内容...