一般窗口通信分为三种:

  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. CSS平滑过渡动画:transition

    <html> <head> <link href="http://cdn.bootcss.com/twitter-bootstrap/3.0.2/css/boo ...

  2. 【sqli-labs】 less48 GET -Error based -Blind -Numeric -Order By Clause(GET型基于盲注的整型Order By从句注入)

    图片还是47...访问的的确是48 这个是基于bool的盲注 http://192.168.136.128/sqli-labs-master/Less-48/?sort=1 and sleep(0.1 ...

  3. (转)Hadoop入门进阶课程

    http://blog.csdn.net/yirenboy/article/details/46800855 1.Hadoop介绍 1.1Hadoop简介 Apache Hadoop软件库是一个框架, ...

  4. Python之模块、正则

    一.模块import 模块的实质就是把要导入模块里面的代码,从上到下执行一遍,找模块的顺序是,先从当前目录下找,找不到的话,再环境变量里面找导入的模块名字最好不要有.,a.import sysprin ...

  5. Git学习总结三(工作区和暂存区、撤销修改)

    工作区和暂存区 工作区(Working Directory) 就是你在电脑里能看到的目录,比如我的learngit文件夹就是一个工作区: 版本库(Repository) 工作区有一个隐藏目录.git, ...

  6. 取textaera里的值

    jQuery的.val()方法是专门用来获取表单元素值的,而textarea也属于表单元素所以可以直接用.val()方法获取. 不过要注意,由于textarea是个双标记因此.text()或.html ...

  7. 【LeetCode】2、Add Two Numbers

    题目等级:Medium 题目描述:   You are given two non-empty linked lists representing two non-negative integers. ...

  8. hdu 4870

    Rating Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Sub ...

  9. Xcode 插件因为UUID原因不能使用解决办法

    Xcode 经常因为一些原因不能使用,需要重新在  ~/Library/Application Support/Developer/Shared/Xcode/Plug-ins目录下对每一个插件包下的p ...

  10. Centos下安装mysql(二进制版)

    1.下载安装包,选择相应的平台.版本,比如,选择64位Linux平台下的MySQL二进制包“Linux-Generic (glibc 2.5)(x86,64-bit),Compressed” 如:#w ...