window.postMessage 父子窗口传值的正确用法

本文介绍了如何在不使用Vuex和Router的情况下,通过postMessage实现两个浏览器窗口之间的通信。首先在父窗口打开子窗口,然后在子窗口中触发postMessage发送数据到父窗口。父窗口通过添加事件监听器来接收并处理子窗口发送的消息。这是一个实用的技术分享,适合前端开发者了解和学习跨页面通信技巧。
摘要由CSDN通过智能技术生成

        接触到这个还是因为碰到一个两年前的项目,现在需要加新功能,这个是一个无vuex、无router的题目资源中心的项目。所以就想到了两个页面在不使用接口传值的方式进行postMessage通信。

        1. 父标签页通过按钮等事件打开了子标签页后,注意:不要关闭父窗口 而是新开一个子窗口。

openChildWindow() {
    window.open('http://www.child.com');
}

        2. 子窗口点击按钮后触发了 window.opener.postmessage(data,origin,[transfer](这个参数我没有使用上))。

// 传递信息到父窗口的触发事件
onclickSendMessage() {
    // 父窗口不能关闭
    if(window.opener) {
        // otherwindow.postmessage(data, origin)
        window.opener.postMessage('Father, I'm coming!', 'http://www.parents.com');
    }
}

        3.父标签页需要在mounted生命周期里就注册addEventListener监听message事件,监听子窗口发来的postmessage。

mounted() {
    let _this = this;
    window.addEventListener('message', event=> {
        if(event.origin.includes('parents')) {
            // 最好对数据进行处理,当使用webpack时 webpack自身会发送postMessage,注意监听                            
            // message时区分具体是自己发来的message还是webpackOK ;
            _this.processData(event.data);
        }
    })
}

        第一次把自己的踩坑经历以及成品,展示出来,非常激动呢~ 希望我的分享你们喜欢,毕竟写blog的时间不长,有什么更好的经验和我这边有什么不妥或不严谨的写法,大家都能给我留个言喔~谢谢啦!

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值