使用postMessage无法在iframe子页面中无法监听到父页面的的message
父级代码:
<script>
$(function () {
$('#bimshow').attr('src', 'http://localhost:12536/');
$('#bimshow')[0].onload = function () {
window.addEventListener("message", (event) => {
window.frames['bimshow'].postMessage({ token: "parent" }, "*");//给指定的iframe发送信息
})
}
})
</script>
iframe代码:在vue项目中 写在一个js文件中
window.parent.postMessage({}, "*");//触发父元素的监听事件
window.addEventListener("message", (event) => {
//监听父元素的postMessage事件
console.log(event.data)
window.removeEventListener("message", () => { });//移除message监听事件,否则会成死循环;
})
{type: 'webpackOk', data: undefined}
data: undefined
type: "webpackOk"
[[Prototype]]: Object
获取到父页面的message
你父级代码有问题,父级向子iframe发送数据,用的是 frame.contentWindow.postMessage,并且应该直接放到iframe.onload里的,不要再加一层window.addEventListener("message"
父页面代码:
子页面代码:
执行后结果: