iframe,结合window.postMessage,实现通信

这是另一种通讯方式:https://baijiahao.baidu.com/s?id=1606945663099800547&wfr=spider&for=pc
我们用的是H5新增的

父页面




    
    Document




    
    



iframe内嵌页面




    
    Document


    
    
    


由于实在vue-cli项目中使用的,内嵌页面和触发条件不再一个页面中,所以需要通过,创建一个空的 Vue 实例作为事件总线。

第一步:创建空实例,并注册到根实例里

let Hub = new Vue(); //创建事件中心
new Vue({
  router,
  store,
  render: h => h(App),
  data:{
    Hub:Hub 
  }
}).$mount('#app')

第二步:Hub触发事件

this.$root.Hub.$emit('wangChange',menuId); //Hub触发事件

第三步:Hub监听事件

 this.$root.Hub.$on('wangChange', (res) => { //Hub接收事件
  })

你可能感兴趣的:(iframe,结合window.postMessage,实现通信)