postMessage详解

postMessage详解目录一、概述二、详解一、概述作用该方法是HTML5引入的API,可以通过异步方式实现跨源通信,多用于窗口间数据通信。它提供了一种受控机制来规避不同源脚本无法通信的限制,只要正确使用,这种方法很安全。什么是跨源同源即指相同的协议、域名或IP、端口号。浏览器具有同源限制,同源脚本可以相互通信,一般非同源(跨源)的脚本文件禁止相互通信。二、详解语法示例-发送程序&…

大家好,又见面了,我是你们的朋友全栈君。

目录

一、概述

二、详解


一、概述

作用

        该方法是HTML5引入的API,可以通过异步方式实现跨源通信,多用于窗口间数据通信。它提供了一种受控机制来规避不同源脚本无法通信的限制,只要正确使用,这种方法很安全。   

什么是跨源

        同源即指相同的协议、域名或IP、端口号。浏览器具有同源限制,同源脚本可以相互通信,一般非同源(跨源)的脚本文件禁止相互通信。

语法

postMessage详解

message事件

        通过绑定window的message事件来监听发送的跨文档消息传输内容。

二、代码示例

示例1

        发送程序如下代码所示。 

<div>
    <input id="text" type="text" value="demo" />
    <button id="btn">发送消息</button>
</div>
<iframe 
    loading="lazy" 
    id="iframe" src="https://c.runoob.com/runoobtest/postMessage_receiver.html" 
    width="300" height="360">
    <p>你的浏览器不支持 iframe。</p>
</iframe>

<script>
    window.onload = function() {
        var receiver = document.getElementById('iframe').contentWindow;
        var btn = document.getElementById('btn');
        btn.addEventListener('click', function (e) {
            e.preventDefault();
            var val = document.getElementById('text').value;
            receiver.postMessage("Hello", "https://c.runoob.com");
        });
    }
</script>

        接收程序如下代码所示。 

<script>
// 监听 message 事件
window.addEventListener('message', function (e) {  
    if (e.origin !== "https://www.runoob.com") {  // 验证消息来源地址
        return;
    }
    console.log("从"+ e.origin +"收到消息: " + e.data);
});
</script>
  • e.source:消息源,消息的发送窗口/iframe
  • e.origin:消息源的URL(可能包含协议、域名或IP、端口),用来验证数据
  • e.data:发送过来的数据

示例2:iframe父子页面通信

        接收消息的一方需要监听message事件。

window.addEventListener(“message”, ()=> { 

});

        父页面向子页面传递信息。

let ifr = document.getElementById("iframe")
ifr.contentWindow.postMessage('父页面向子页面发送消息', "*")

// or

ifr.contentWindow.postMessage('父页面向子页面发送消息', "http://10.192.195.166:56225/son.html")

        子页面向父页面传递数据。

window.parent.postMessage('子页面向父页面发送消息','*')
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/159842.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • java集合——HashSet的用法「建议收藏」

    java集合——HashSet的用法「建议收藏」java集合——HashSet的用法一、HashSet的构造HashSethashset=newHashSet();二、HashSet添加元素//向hashset中添加一个字符串hashset.add(“abc”);//向hashset中添加一个整数hashset.add(1);//向hashset中添加一个字符hashset.add(‘a’);

    2022年7月14日
    16
  • matlab声源定位算法实现_MATLAB程序

    matlab声源定位算法实现_MATLAB程序这是通过传统互相关的方法来进行声源定位的程序,做完互相关之后,红色标注的程序行,应该如何理解呢,是通过什么方法来实现最终延迟差的估计的呢?clclearallcloseall%%%*各参数设置*%–声源相关参数fm=2000;%Hz:信源调频信号最高频率周期0.5msTs=0.2;%s:信源周期0.2s%–采样和信号处理相关参数fs=10*fm;%采样率…

    2022年9月22日
    0
  • 树莓派基础教程_树莓派从入门到精通

    树莓派基础教程_树莓派从入门到精通截至目前(20210405),树莓派最新版本为4B,如下图所示:下载最新Raspbian系统镜像1.首先进入树莓派官网:https://www.raspberrypi.org/,点击Software2.点击红框标出的Seealldowmloadoptions3.选择一个进行下载推荐下载中间的桌面版。注意,可以点击Downloadtorrent种子下载会比较快。下载完成后得到的是一个压缩文件,解压缩后是一个.img文件,该文件需要烧录到SD中。下面这是老版的官网界面如果你想下载以前

    2022年10月15日
    0
  • docker使用教程视频_docker到底怎么用

    docker使用教程视频_docker到底怎么用前言docker主要用于运维,当然了,开发也可以用,可以在启动应用项目的时候使用docker方式,docker是虚拟化技术,每一个docker容器都是一个linux虚拟机,而且还可以根据不同的应用定制,最小的可以直接依赖linux内核,仅仅几M就可以运行。下面,正式开始。 注意:如果是使用docker-compose方式,只看到第三的第6即可。 一、安装dockercent…

    2022年10月15日
    0
  • springboot上传文件到阿里云

    springboot上传文件到阿里云springboot上传文件到OSS前提声明,文章借鉴了https://blog.csdn.net/wonder_dog/article/details/81152307#commentsedit博客,大神在我没有思路的时候提供了最简洁明了的教程,话不多说:写代码吧1.首先依赖:<dependency><groupId>com.aliyun.oss&…

    2022年6月9日
    70
  • 当小样本遇上机器学习 fewshot learning

    当小样本遇上机器学习 fewshot learning引言深度学习(deeplearning)已经广泛应用于各个领域,解决各类问题,例如在图像分类问题下,如图1,区分这10类目标的准确率目前可以轻松做到94%。然而,deeplearning是一种datahungry的技术,需要大量的标注样本才能发挥作用。图1现实世界中,有很多问题是没有这么多的标注数据的,获取标注数据的成本也非常大,例如在医疗领域、安全领域等。因此,我们现在讨论的是…

    2022年4月28日
    62

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号