vue与iframe双向通信

iframe通信
父vue
<iframe id="myiframe" ref="myiframe" src="./child.html" width="100%" height="400px"></iframe>

//获取子iframe三种方法
   let iframeWin = this.$refs.myiframe.contentWindow;
   //let iframeWin = document.getElementById("myiframe").contentWindow;
  //let iframeWin = window.frames["myiframe"];


//父向子传
let msg=''
iframeWin.postMessage(msg,"*");
//父监听子
window.addEventListener("message", event => {
console.log('子向父传来的数据',event.data)
})

    
iframe
//子接收父,监听message事件,采用冒泡传递方式
    window.addEventListener("message",receiveMessage,false);
    function receiveMessage(event){
        let data = event.data
        console.log('我是父页面传递过来的', data)
    }
//子向父传
function sendMessage(){
        let data = 'Hello from child!'
        window.parent.postMessage(data, "*")
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值