我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

众所周知,在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新窗口调用父窗口内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

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

由于开发需要,我需要在登录成功请求成功后,调用父窗口的一个点击事件方法,这篇文章主要给大家介绍了关于vue跨窗口通信之新窗口调用父窗口的相关资料,需要的朋友可以参考下
2023-01-17

React常见跨窗口通信方式实例详解

这篇文章主要为大家介绍了React常见跨窗口通信方式实例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2022-11-13

编程热搜

目录