当前位置: 代码网 > it编程>前端脚本>Vue.js > vue跨窗口通信之新窗口调用父窗口方法实例

vue跨窗口通信之新窗口调用父窗口方法实例

2024年05月20日 Vue.js 我要评论
众所周知,在vue中bus等工具只能跨组件通信,如何实现跨窗口通信呢?场景如下,我们在a窗口中新开了b窗口,想在b窗口中调用a窗口的方法?这里还总结了一点window事件的方法:window.open

众所周知,在vue中bus等工具只能跨组件通信,如何实现跨窗口通信呢?

场景如下,我们在a窗口中新开了b窗口,想在b窗口中调用a窗口的方法?

这里还总结了一点window事件的方法:

window.opener.location.reload()  这样关闭b窗口后会刷新整个a窗口,体验效果不是很好

window.onunload                   在关闭窗口之后触发

window.opener                       获取父页面的window元素

注:

1.window.opener 实际上就是通过window.open()打开的窗体的父窗体

2.window.opener.父页面中的方法();//调用父页面中的方法

location.reload()                     刷新页面

window.close()                       关闭window.open()打开的窗口

window.onbeforeunload         关闭窗口前执行事件

a窗口:

mounted() {
   // 注:getbpagelist是提供给新窗口b触发的,实际上触发的是a的getapagelist方法
    window["getbpagelist"] = (params) => {
      this.getapagelists(params);
    };
methods: {
    async getapagelists(){
     
        let res = await getpagelist()
        ......
    },

    //点击新打开一个窗口b
    detailsview(data) {
      window.open(`....../${data.id}`);
    },
 
}

b窗口调用a窗口方法

注:具体场景可以很多,比如放在点击事件中,或者关闭窗口前等
       methods:{
			emitawindow(){
             //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新窗口调用父窗口内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com