Vue进阶(九十二):应用 postMessage 实现窗口通信_vue使用postmessage
最后
其实前端开发的知识点就那么多,面试问来问去还是那么点东西。所以面试没有其他的诀窍,只看你对这些知识点准备的充分程度。so,出去面试时先看看自己复习到了哪个阶段就好。
这里再分享一个复习的路线:(以下体系的复习资料是我从各路大佬收集整理好的)
《前端开发四大模块核心知识笔记》
最后,说个题外话,我在一线互联网企业工作十余年里,指导过不少同行后辈。帮助很多人得到了学习和成长。
开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】
我意识到有很多经验和知识值得分享给大家,也可以通过我们的能力和经验解答大家在IT学习中的很多困惑,所以在工作繁忙的情况下还是坚持各种整理和分享。
一、拓展阅读
在前端应用中,窗口间通信应用场景很多,比如弹出qq登录认证窗。
二、postMessage 语法
window.postMessage(msg,targetOrigin)
注意⚠️postMessage
要通过window
对象调用!因为这里的window
不只是当前window
!大部分使用postMessage
的时候,都不是本页面的window
,而是其他网页的window
!如:
iframe
的contentWindow
;- 通过
window.open
方法打开新窗口的window
; window.opener
如果你使用postMessage
时没有带window
,就是用的本页面的window
来调用它。
2.1 参数说明
msg
这是要传递的消息。它可以是一切javascript
参数,如字符串,数字,对象,数组,而不是和json
一样只局限于字符串。
targetOrigin
这个参数称作“目标域”,注意⚠️,是目标域不是本域!比如,你想在2.com的网页上往1.com网页上传消息,那么这个参数就是“http://1.com/”,而不是2.com.
另外,一个完整的域包括:协议,主机名,端口号。如:http://g.cn:80/
window.open
方法会返回一个窗口对象,使用这个对象可以向子窗口发送消息,而子窗口可以通过window.opener
向父窗口发送消息,示例如下:
// index.html
<body>
<button onclick="opwin()">打开</button>
<script type="text/javascript">
function opwin() {
//保留窗口对象
var popup = window.open("test.html", "\_blank");
}
function receiveMessage(event) {
//event.origin是指发送的消息源,一定要进行验证!!!
if (event.origin !== "http://localhost")return;
//event.data是发送过来的消息。
console.log(event.data);
//event.source是指子窗口,主动向子窗口发送消息可以用popup
//postMessage有两个参数,消息和自己的源(例如http://www.baidu.com),自己的源应该和目标源相同。否则发送会失败。
event.source.postMessage("我是主窗口,我接收到消息了",window.location);
}
//添加消息接收函数
window.addEventListener("message", receiveMessage, false);
</script>
</body>
// test.html
### 总结
大厂面试问深度,小厂面试问广度,如果有同学想进大厂深造一定要有一个方向精通的惊艳到面试官,还要平时遇到问题后思考一下问题的本质,找方法解决是一个方面,看到问题本质是另一个方面。还有大家一定要有目标,我在很久之前就想着以后一定要去大厂,然后默默努力,每天看一些大佬们的文章,总是觉得只有再学深入一点才有机会,所以才有恒心一直学下去。
**[开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】](https://bbs.csdn.net/topics/618166371)**
![](https://img-blog.csdnimg.cn/img_convert/718310d106ab948d6f467d78e08b1aed.png)
更多推荐
所有评论(0)