使用postMessage实现iframe跨域通信的示例代码

1、父页面内容



    
        
        
    
    
        

主页面

主页面跨域接收消息区域

2、子页面

(我这里在在vue页面里做的测试,vue模板的html代码就不展示了)

mounted() {

            //接收父页面传过来的数据
            window.addEventListener('message', function(event) {    
                
                // 处理addEventListener执行两次的情况,避免获取不到data
                // 因此判断接收的域是否是父页面
                if(event.origin.includes("http://127.0.0.1:8848")){
                    console.log(event);
                    document.getElementById('message').innerHTML = "收到" + event.origin + "消息:" + event.data;
                                        
                    //把数据传递给父页面 > top.postMessage(要传递的数据,父页面的url访问地址)
                    top.postMessage("子页面消息收到", 'http://127.0.0.1:8848/boatStaticHtml/iframe%E9%80%9A%E4%BF%A1.html');                
                }
            }, false);    

        }

3、效果图展示

使用postMessage实现iframe跨域通信的示例代码_第1张图片

到此这篇关于使用postMessage实现iframe跨域通信的文章就介绍到这了,更多相关postMessage iframe跨域通信内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

你可能感兴趣的:(使用postMessage实现iframe跨域通信的示例代码)