项目中使用到iframe,iframe跨域通信需要使用postMessage发送消息,addEventListener接收消息。
原先是获取当前窗口的数据发送过去。
const _iframe = document.getElementById('iframeViewer').contentWindow
let _obj = res.data.data
_obj.type = 'view'
_obj.currentProcessInstanceId = row.id
let Base64 = require('js-base64').Base64
_obj.processXml = Base64.decode(res.data.data.processXml)
_iframe.postMessage(JSON.stringify(_obj), '*')
后来项目需求更新,需要将本来的窗口多加几个菜单,可以进行页面切换。加了新的菜单之后就出现了问题,postMessage发送出了消息,控制台打印出来addEventListener接收到的消息变成了webpack相关。
bug如下:
问了大哥,发现问题可能是因为webpack自身会发送postMessage,需要区分接收到的是webpack发的还是自己发的。另外iframe是动态生成的,未加载好就发送postMessage&