一般窗口通信分为三种:

  1. iframe嵌套:多个iframe之间通信。

    • 父页面操作子页面元素:oFrame.contentWindow.document.body。
    • 父页面调用子页面方法:oFrame.contentWindow.functionName()。
    • 子页面调用父页面元素:window.top/parent/window
     <!DOCTYPE html>
    <html>
    <head>
    <meta charset="UTF-8">
    <title></title>
    </head>
    <body>
    <iframe id="myFrame" src="Iframe2.html"></iframe><br />
    <input type="button" value="改变子窗口的背景色" id="btn1" />
    <input type="button" value="调用子窗口的方法" id="btn2" />
    </body>
    </html>
    <script type="text/javascript">
    window.onload = function(){
    var myFrame = document.getElementById("myFrame");
    var oBtn1 = document.getElementById("btn1");
    var oBtn2 = document.getElementById("btn2");
    oBtn1.onclick = function(){
    myFrame.contentWindow.document.body.style.background = "greenyellow";
    }
    oBtn2.onclick = function(){
    myFrame.contentWindow.chlidWindowHandler();
    }
    }
    function parentWindowHandler(){
    alert("这是父窗口的方法,可以被子窗口调用");
    }
    </script>
     <!DOCTYPE html>
    <html>
    <head>
    <meta charset="UTF-8">
    <title></title>
    </head>
    <body>
    <h1>这是iframe2</h1>
    <input type="button" value="改变父窗口的背景色" id="btn1" />
    <input type="button" value="调用父窗口的方法" id="btn2" />
    </body>
    </html>
    <script type="text/javascript">
    window.onload = function(){
    var oBtn1 = document.getElementById("btn1");
    var oBtn2 = document.getElementById("btn2");
    oBtn1.onclick = function(){
    window.top.document.body.style.background = "deepskyblue";
    console.log(window.top);
    }
    oBtn2.onclick = function(){
    window.top.parentWindowHandler();
    }
    }
    function chlidWindowHandler(){
    alert("这是子窗口的方法,可以被父窗口调用");
    }
    </script>
  2. 用window.open()方法打开一个新的窗口。
      • 父页面操作子页面元素:window.open()打开子页面时,返回子页面窗口对象。
      • 子页面操作父页面元素:window.opener即为父窗口对象。
     <!DOCTYPE html>
    <html>
    <head>
    <meta charset="UTF-8">
    <title></title>
    <style type="text/css">
    input{margin:10px;}
    </style>
    </head>
    <body>
    <input type="button" name="" id="btn1" value="打开一个新窗口" /><br />
    <input type="button" name="" id="btn2" value="改变子窗口背景色" /><br />
    <input type="button" name="" id="btn3" value="调用子窗口方法" />
    </body>
    </html>
    <script type="text/javascript">
    window.onload = function(){
    var oBtn1 = document.getElementById("btn1");
    var oBtn2 = document.getElementById("btn2");
    var oBtn3 = document.getElementById("btn3"); var childWin = null;
    oBtn1.onclick = function(){
    childWin = window.open("child.window.html","_blank");
    }
    oBtn2.onclick = function(){
    //方法1
    childWin.document.body.style.background = "greenyellow";
    }
    oBtn3.onclick = function(){
    childWin.childWinHandler();
    }
    }
    function parentWinHandler(){
    alert("这是父窗口方法,可以被子窗口调用");
    }
    </script>
     <!DOCTYPE html>
    <html>
    <head>
    <meta charset="UTF-8">
    <title></title>
    </head>
    <body>
    <input type="button" name="" id="btn1" value="改变父窗口背景色" />
    <input type="button" name="" id="btn2" value="调用父窗口的方法" />
    </body>
    </html>
    <script type="text/javascript">
    window.onload = function(){
    var oBtn1 = document.getElementById("btn1");
    var oBtn2 = document.getElementById("btn2");
    oBtn1.onclick = function(){
    window.opener.document.body.style.background = "deepskyblue";
    }
    oBtn2.onclick = function(){
    window.opener.parentWinHandler();
    }
    } function childWinHandler(){
    alert("这是子窗口的事件,可以被父窗口调用");
    }
    </script>
  3. html5t提供的postMessage方法和message事件。
      • postMessage():接收消息窗口对象.postMessage("发送的数据","接收的域"); 这里的域一定要带上协议
      • message事件:接收消息窗口监听message事件,事件对象中包含有origin属性和data属性。其中ev.origin可以获取发送数据的域,ev.data获取发送的具体数据。
     <!DOCTYPE html>
    <html>
    <head>
    <meta charset="UTF-8">
    <title></title>
    </head>
    <body>
    <iframe id="myFrame" src="http://localhost:63342/XChart/Iframe2.html" width="600px;"></iframe><br />
    <input type="button" value="向子窗口发送数据" id="btn" />
    </body>
    </html>
    <script type="text/javascript">
    window.onload = function(){
    var myFrame = document.getElementById("myFrame");
    var oBtn = document.getElementById("btn"); oBtn.onclick = function(){
    myFrame.contentWindow.postMessage("testData","http://localhost:63342");
    }
    }
    function parentWindowHandler(){
    alert("这是父窗口的方法,可以被子窗口调用");
    }
    </script>
     <!DOCTYPE html>
    <html>
    <head>
    <meta charset="UTF-8">
    <title></title>
    </head>
    <body>
    <p>http://localhost:63342/XChart/Iframe2.html</p>
    </body>
    </html>
    <script type="text/javascript">
    window.onload = function(){
    window.addEventListener("message",function(ev){
    alert("父窗口向子窗口发送的数据是:" + ev.data);
    alert("数据来源是:" + ev.origin);
    })
    } </script>

html5 窗口之间的通信的更多相关文章

  1. 父窗口,子窗口之间的JS"通信"方法

    今天需要在iframe内做一个弹窗,但使用弹窗组件的为子窗口,所以弹窗只在子窗口中显示掩膜层和定位,这样不符合需求. 后来晓勇哥指点,了解到一个以前一直没关注到的东西,每个窗口的全局变量,其实都存在对 ...

  2. 使用HTML5 的跨域通信机制进行数据同步

    离线应用系统的设计目标就是在网络离线情况下依然可以操作我们的应用系统,并在网络畅通的情况下与服务器进行数据交互. 所以离线应用系统最终会做成类似C/S架构的客户端应用程序.这边基于Chrome或者 S ...

  3. Delphi 两个应用程序(进程)之间的通信

    两个应用程序之间的通信实际上是两个进程之间的通信.由于本人知识有限,决定应用消息来实现.需要用到的知识: 1.RegisterWindowMessage(); //参数类型:pchar:返回值:Lon ...

  4. Android模拟器的ip获取以及模拟器之间socket通信

    Android模拟器的ip获取以及模拟器之间socket通信           http://kalogen.iteye.com/blog/1565507 作者:李波 实现网络五子棋时用到了两个设备 ...

  5. VC中利用多线程技术实现线程之间的通信

    当前流行的Windows操作系统能同时运行几个程序(独立运行的程序又称之为进程),对于同一个程序,它又可以分成若干个独立的执行流,我们称之为线程,线程提供了多任务处理的能力.用进程和线程的观点来研究软 ...

  6. 网络编程之Socket的TCP协议实现客户端与客户端之间的通信

    我认为当你学完某个知识点后,最好是做一个实实在在的小案例.这样才能更好对知识的运用与掌握 如果你看了我前两篇关于socket通信原理的入门文章.我相信对于做出我这个小案列是完全没有问题的!! 既然是小 ...

  7. 基于WSAAsyncSelect模型的两台计算机之间的通信

    任务目标 编写Win32程序模拟实现基于WSAAsyncSelect模型的两台计算机之间的通信,要求编程实现服务器端与客户端之间双向数据传递.客户端向服务器端发送"请输出从1到1000内所有 ...

  8. MFC 窗口分割与通信

    一.关于CSplitterWnd类我们在使用CuteFtp或者NetAnt等工具的时候,一般都会被其复杂的界面所吸引,在这些界面中窗口被分割为若干的区域,真正做到了窗口的任意分割. 那么我们自己如何创 ...

  9. JS观察者设计模式:实现iframe之间快捷通信

    观察者设计模式又称订阅发布模式,在JS中我们习惯叫做广播模式,当多个对象监听一个通道时,只要发布者向该通道发布命令,订阅者都可以收到该命令,然后执行响应的逻辑.今天我们要实现的就是通过观察者设计模式, ...

随机推荐

  1. Vue项目优化首屏加载速度

    Vue项目部署上线后经常会发现首屏加载的速度特别慢:那么有那写能做的简单优化呢 一.路由的懒加载 路由懒加载也就是 把不同路由对应的组件分割成不同的代码块,然后当路由被访问的时候才加载对应组件. 结合 ...

  2. 汇编:MSR/MRS/BIC指令

    1.MRS指令MRS指令的格式为:MRS{条件}   通用寄存器,程序状态寄存器(CPSR或SPSR)MRS指令用于将程序状态寄存器的内容传送到通用寄存器中.该指令一般用在以下两种情冴: Ⅰ.当需要改 ...

  3. 北京Linux运维培训怎么选?

    北京的地理优势和经济优势基本无需多言,作为全国机会最多的地方,吸引了无数的北漂前赴后继.作为中国互联网中心之一,北京有海量的运维岗位正在等待大家淘金.北京的Linux云计算培训业蓬勃发展. 云计算早已 ...

  4. 【Linq】

    " }; var l1 = strs.ToLookup(a => "a"); //Key=a elements=1,3 var l2 = strs.ToLookup ...

  5. Silverlight之我见——数据批示(1)

    第一次听到这个概念,你是否有点陌生?MSDN上也没有特意的去说明.不要看到这个名词不太熟悉,其实数据批示,玩过C#的人都会非常熟悉,所谓数据批示,其本质就是特性(Attribute),怎么样,现在有点 ...

  6. play snake on linux

    在写完超Low的windows上的贪吃蛇后 被人吐槽了几个方面: 1.界面真的Low,开始,结束,游戏中,都太简陋了... 2.每次都清屏在输出字符矩阵的解决方案...太晃眼了 3.一个BUG,为了解 ...

  7. UVa - 12664 - Interesting Calculator

    先上题目: 12664 Interesting CalculatorThere is an interesting calculator. It has 3 rows of button.• Row ...

  8. 【ACM】nyoj_132_最长回文子串_201308151713

    最长回文子串 时间限制:1000 ms  |  内存限制:65535 KB 难度:4   描述 输入一个字符串,求出其中最长的回文子串.子串的含义是:在原串连续出现的字符串片段.回文的含义是:正着看和 ...

  9. EF--model is being created异常

    使用EF的时候出现了下面的异常,我使用了TASK和saveChangeAsync()异步 The context cannot be used while the model is being cre ...

  10. Java和JS MD5加密-附盐值加密demo

    JAVA和JS的MD5加密 经过测试:字母和数据好使,中文不好使. 源码如下: ** * 类MD5Util.java的实现描述: * */public class MD5Util { // 获得MD5 ...