// iframe内嵌项目
methods: {
callWindowTask(nodeKeys) {
// 触发方法通过window.parent.postMessage向外层传递消息
window.parent.postMessage({
channel: ‘Connect’,
type: ‘Ready’,
info: {
…
}
}, '’) // ‘’可以修改为具体域名或者ip
}
}
// 外层项目
create() {
// 监听浏览器对象message方法
window.addEventListener(‘message’, function (res) {
// messageEvent对象的data就是传递过来的数据
console.log(res.data)
})
}
本文探讨了如何利用`window.postMessage`方法在iframe与外层页面之间进行安全的数据通信。在示例中,展示了如何在内部项目中调用`callWindowTask`方法触发消息传递,然后在外层项目中监听`message`事件来接收并处理来自子窗口的数据。这种方法在现代Web开发中常用于实现跨域通信和组件间通信。
341

被折叠的 条评论
为什么被折叠?



