我的编程空间,编程开发者的网络收藏夹
学习永远不晚

html5跨域通讯中postMessage的用法

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

html5跨域通讯中postMessage的用法

这篇文章给大家介绍html5跨域通讯中postMessage的用法,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

postMessagePortal.html 页面代码

代码如下:


<!DOCTYPE html>
<title>标题</title>
<link rel="stylesheet" href="styles.css">
<link rel="icon" href="http://apress.com/favicon.ico">
<script></p> <p>var targetOrigin = "http://22527.vhost20.boxcdn.cn";</p> <p>var defaultTitle = "Portal";
var notificationTimer = null;</p> <p>function messageHandler(e) {
   if (e.origin == targetOrigin) {
       notify(e.data);
   } else {
       // ignore messages from other origins
   }
}</p> <p>function sendString(s) {
   document.getElementById("widget").contentWindow.postMessage(s, targetOrigin);
}</p> <p>
function notify(message) {
   stopBlinking();
   blinkTitle(message, defaultTitle);
}</p> <p>function stopBlinking() {
   if (notificationTimer !== null) {
       clearTimeout(notificationTimer);
   }
   document.title = defaultTitle;
}</p> <p>function blinkTitle(m1, m2) {
   document.title = m1;
   notificationTimer = setTimeout(blinkTitle, 1000, m2, m1)
}</p> <p>function sendStatus() {
   var statusText = document.getElementById("statusText").value;
   sendString(statusText);
}</p> <p>function loadDemo() {
   document.getElementById("sendButton").addEventListener("click", sendStatus, true);
   document.getElementById("stopButton").addEventListener("click", stopBlinking, true);
   sendStatus();
}
window.addEventListener("load", loadDemo, true);
window.addEventListener("message", messageHandler, true);</p> <p></script></p> <p><h2>跨域通讯</h2>
传递信息:<input type="text" id="statusText" value="Online">
<button id="sendButton">确定</button>


<iframe id="widget" class="lazy" data-src="http://22527.vhost20.boxcdn.cn/postMessageWidget.html"></iframe>
<p>
   <button id="stopButton">停止标题闪烁</button>
</p>


postMessageWidget.html页面的代码

代码如下:


<!DOCTYPE html>
<title>标题</title>
<link rel="stylesheet" href="styles.css">
<script></p> <p>var targetOrigin = "http://www.weixiu0376.cn";</p> <p>// TODO whitelist array</p> <p>function messageHandler(e) {
   if (e.origin === "http://www.weixiu0376.cn") {
       document.getElementById("status").textContent = e.data;
   } else {
       // ignore messages from other origins
   }
}</p> <p>function sendString(s) {
   window.top.postMessage(s, targetOrigin);
}</p> <p>function loadDemo() {
   document.getElementById("actionButton").addEventListener("click",
       function() {
           var messageText = document.getElementById("messageText").value;
           sendString(messageText);
       }, true);</p> <p>}
window.addEventListener("load", loadDemo, true);
window.addEventListener("message", messageHandler, true);</p> <p></script>
<p>显示接收信息: <strong id="status"></strong><p>
<div>
   <input type="text" id="messageText" value="填写消息内容">
   <button id="actionButton">发送消息</button>
</div>

关于html5跨域通讯中postMessage的用法就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

html5跨域通讯中postMessage的用法

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何在html5中使用postMessage解决跨域通信

本篇文章给大家分享的是有关如何在html5中使用postMessage解决跨域通信,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。postmessage解析HTML5提供了新型机
2023-06-09

如何在html5中使用postMessage前端跨域并前端监听

这篇文章将为大家详细讲解有关如何在html5中使用postMessage前端跨域并前端监听,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。第一步、架设两个不同端口的服务我们这里用koa2来搭建
2023-06-09

vue中proxy代理的用法(解决跨域问题)

这篇文章主要介绍了vue中的proxy代理的用法(解决跨域问题),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2022-12-09

java项目中使用Cors实现后端跨域的法

今天就跟大家聊聊有关java项目中使用Cors实现后端跨域的法,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。代码如下:package com.lvluo.web.filter.Cor
2023-05-31

vue项目中常用解决跨域的方法总结(CORS和Proxy)

在vue项目中,一般我们会遇到跨域的问题,vue项目中解决跨域是非常简单的,下面这篇文章主要给大家介绍了关于vue项目中常用解决跨域的方法,主要解释CROS和Proxy两种方式,需要的朋友可以参考下
2022-12-08

.NET Core跨平台串口通讯使用SerialPortStream基础类库问题的解决方法

这篇文章跟大家分析一下“.NET Core跨平台串口通讯使用SerialPortStream基础类库问题的解决方法”。内容详细易懂,对“.NET Core跨平台串口通讯使用SerialPortStream基础类库问题的解决方法”感兴趣的朋友
2023-06-26

使用adb命令向Android模拟器中导入通讯录联系人的方法

本文实例讲述了使用adb命令向Android模拟器中导入通讯录联系人的方法。分享给大家供大家参考。具体实现方法如下: 使用adb提供的命令, 可以非常方便地从PC中将通讯录导入android模拟器中. 首先要先准备好固定格式的contact
2022-06-06

编程热搜

目录