一般窗口通信分为三种:

  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. Python开发工具搭建-Pycharm

    PyCharm2017. 3.X专业版 安装使用. 注册码激活 本文以 Windows系统 为例: 1.开发工具获取及下载 Anaconda(Python 的集成工具 ) 下载地址: https:// ...

  2. Android本地消息推送

    项目介绍:cocos2dx跨平台游戏 项目需求:实现本地消息推送,需求①:定点推送:需求②:根据游戏内逻辑实现推送(比如玩家体力满时,需要计算后到点推送):需求③:清理后台程序或重启后依然能够实现本地 ...

  3. windows环境搭建ui自动化环境

    windows环境安装python虚拟环境 https://www.cnblogs.com/suke99/p/5355894.html https://www.cnblogs.com/jiuyang/ ...

  4. Luogu P2866 [USACO06NOV]糟糕的一天Bad Hair Day

    P2866 [USACO06NOV]糟糕的一天Bad Hair Day 题目描述 Some of Farmer John's N cows (1 ≤ N ≤ 80,000) are having a ...

  5. vim使用配置-python

    安装vundle git clone https://github.com/gmarik/Vundle.vim.git ~/.vim/bundle/Vundle.vim 添加配置文件 vim ~/.v ...

  6. SGU180 Inversions(树状数组求逆序数)

    题目: 思路:先离散化数据然后树状数组搞一下求逆序数. 离散化的方法:https://blog.csdn.net/gokou_ruri/article/details/7723378 自己对用树状数组 ...

  7. uva 133(The Dole Queue UVA - 133)

    一道比较难想的模拟题,用了队列等东西,发现还是挺难做的,索性直接看了刘汝佳的代码,发现还是刘汝佳厉害! 代码本身难度并不是很大,主要还是p=(p+n+d-1)%n+1;这一句有些难度,实际上经过自己的 ...

  8. 【模板】求1~n的整数的乘法逆元

    洛谷3811 先用n!p-2求出n!的乘法逆元 因为有(i-1)!-1=i!-1*i (mod p),于是我们可以O(n)求出i!-1 再用i!-1*(i-1)!=i-1 (mod p)即是答案 #i ...

  9. Python 2 声明变量 输入输出 练习

    变量: 代指,用于将具体信息对应到一个值,便于反复使用时方便调用.例如  name = ("斯诺登")   变量声明规则:以字母开头的 字母数字下划线的组合.且不能是python代 ...

  10. NOI2017爆零记[AFO]

    WC2017 12分……全省第一…… APIO2017 4分……全省第二…… 千言万语汇成两个表格 NOI2017 114分(笔试100+一试4+二试5+A类5)……全省第三…… 全场最菜…… day ...