JavaScript实现的双向跨域插件分享


Posted in Javascript onJanuary 31, 2015

由于浏览器(同源策略)限制,JavaScript 跨域的问题,一直是一个颇为棘手的问题。HTML5 提供了跨文档消息传输的功能,在网页文档之间互相接收与发送信息。使用这个功能,不仅同源(域 + 端口号)的 Web 网页之间可以互相通信,还可以在两个不同域名之间实现跨域通信。

跨文档消息传输Cross Document Messaging提供了postMessage方法在不同网页文档之间互相传递数据,支持实时消息传递。现在很多浏览器都将支持这个功能,比如Google Chrome 2.0+、Internet Explorer 8.0+、Firefox 3.0+、Opera 9.6+、Safari 4.0+等

那么,IE6、IE7等不支持 HTML5的浏览器怎么办?

可以使用window.name方法,因为window.name的修改不涉及跨域问题,虽然使用起来不是特别理想,但效果还可以接受。
但是,我们总不能每次涉及到跨域都去写一遍window.postMessage、window.addEventListener、window.name等等这些内容吧。

为此,我把这整个跨域过程抽象出来,封装成一个JavaScript 插件,解决双向跨域问题,实现不同网页文档之间的实时通信,可以在两个不同域名之间实现跨域通信。

demo下载地址:http://xiazai.3water.com/201501/other/jcrossdomain_v2.rar,版本v2

javascript跨域插件jcrossdomain.js

(function (win){

  /** 

   * 没有开花的树 

   * 2013/12/07 17:12 

   */ 

  var _jcd = {

    isInited : false,

    elmt : false,

    hash : '',

    delims : ',',

    rand : function(){

      return (new Date).getTime()

    },

    msg : function(){

      alert('Warning: You must call init function at first');

    },

    init : function(callback, elmt){

      if(_jcd.isInited == true)

        return;

      _jcd.isInited = true;

      _jcd.elmt = elmt;

      if(win.postMessage){

        //浏览器支持 HTML5 postMessage 方法

        if(win.addEventListener){

          //支持火狐、谷歌等浏览器

          win.addEventListener("message", function(ev){

            callback.call(win, ev.data);

          },false);

        }else if(win.attachEvent){

          //支持IE浏览器

          win.attachEvent("onmessage", function(ev){

            callback.call(win, ev.data);

          });

        }

        _jcd.msg = function(data){

          _jcd.elmt.postMessage(data, '*');

        }

      }else{

        //浏览器不支持 HTML5 postMessage 方法,如IE6、7

        setInterval(function(){

          if (win.name !== _jcd.hash) {

            _jcd.hash = win.name;

            callback.call(win, _jcd.hash.split(_jcd.delims)[1]);

          }

        }, 50);

        _jcd.msg = function(data){

          _jcd.elmt.name = _jcd.rand() + _jcd.delims + data;

        }

      }

    }

  };
  var jcd = {
    initParent : function(callback, iframeId){

      _jcd.init(callback, document.getElementById(iframeId).contentWindow);

    },
    initChild : function(callback){

      _jcd.init(callback, win.parent);

    },
    sendMessage : function(data){

      _jcd.msg(data);

    }
  };

  win.jCrossDomain = jcd;

})(window);

父网页中调用方法:

//自定义回调函数

var cb = function(msg){

  alert("get msg:" + msg);

};
//初始化,载入回调函数和 iframe 的id

jCrossDomain.initParent(cb, 'iframeA');
//发消息

jCrossDomain.sendMessage('hello, child');

子网页中调用方法:

//自定义回调函数

var cb = function(msg){

  alert("get msg:" + msg);

};
//初始化,载入回调函数

jCrossDomain.initChild(cb);
//发消息

jCrossDomain.sendMessage('hello, parent');

模拟测试小提示:
为了实现不同域之间的通信,可以在操作系统的 hosts 文件添加两个域名,进行模拟。

hosts 文件中添加两个不同的域名
127.0.0.1  parent.com
127.0.0.1  child.com

程序猿的进化过程:

JavaScript实现的双向跨域插件分享

Javascript 相关文章推荐
JavaScript设计模式之观察者模式(发布者-订阅者模式)
Sep 24 Javascript
jQuery中contents()方法用法实例
Jan 08 Javascript
js进行表单验证实例分析
Feb 10 Javascript
浅谈js中的闭包
Mar 16 Javascript
js从外部获取图片的实现方法
Aug 05 Javascript
jQuery实现导航样式布局操作示例【可自定义样式布局】
Jul 24 jQuery
webpack4+express+mongodb+vue实现增删改查的示例
Nov 08 Javascript
原生js实现trigger方法示例代码
May 22 Javascript
vue router总结 $router和$route及router与 router与route区别
Jul 05 Javascript
Javascript 类型转换、封闭函数及常见内置对象操作示例
Nov 15 Javascript
Vue开发中常见的套路和技巧总结
Nov 24 Vue.js
11个Javascript小技巧帮你提升代码质量(小结)
Dec 28 Javascript
JavaScript判断变量是否为空的自定义函数分享
Jan 31 #Javascript
分享两个手机访问pc网站自动跳转手机端网站代码
Dec 24 #Javascript
js判断登录与否并确定跳转页面的方法
Jan 30 #Javascript
jQuery知识点整理
Jan 30 #Javascript
浅谈jquery回调函数callback的使用
Jan 30 #Javascript
jQuery修改class属性和CSS样式整理
Jan 30 #Javascript
javascript中AJAX用法实例分析
Jan 30 #Javascript
You might like
PHP+SQL 注入攻击的技术实现以及预防办法
2010/12/29 PHP
php setcookie(name, value, expires, path, domain, secure) 参数详解
2013/06/28 PHP
php操作redis常见方法示例【key与value操作】
2020/04/14 PHP
安装PHP扩展时解压官方 tgz 文件后没有configure文件无法进行配置编译的问题
2020/08/26 PHP
Js+XML 操作
2006/09/20 Javascript
JavaScript对象模型-执行模型
2008/04/28 Javascript
六款帮助你实现惊艳视差滚动效果的jQuery插件
2012/09/14 Javascript
如何让div span等元素能响应键盘事件操作指南
2012/11/13 Javascript
JS替换文本域内的回车示例
2014/02/18 Javascript
javascript实现表单提交后,提交按钮不可用的方法
2015/04/18 Javascript
TypeError document.getElementById(...) is null错误原因
2015/05/18 Javascript
JavaScript简单遍历DOM对象所有属性的实现方法
2015/10/21 Javascript
jQuery新窗口打开外链接
2016/07/21 Javascript
js基础之DOM中元素对象的属性方法详解
2016/10/28 Javascript
javascript输出AscII码扩展集中的字符方法
2016/12/26 Javascript
JavaScript Date 知识浅析
2017/01/29 Javascript
通过示例彻底搞懂js闭包
2017/08/10 Javascript
Vue 中的compile操作方法
2018/02/26 Javascript
官方推荐react-navigation的具体使用详解
2018/05/08 Javascript
更改BootStrap popover的默认样式及popover简单用法
2018/09/13 Javascript
js生成1到100的随机数最简单的实现方法
2020/02/07 Javascript
[00:55]深扒TI7聊天轮盘语音出处3
2017/05/11 DOTA
[03:24][TI9纪实] Dota奶爸
2019/08/22 DOTA
python获取一组数据里最大值max函数用法实例
2015/05/26 Python
python smtplib发送带附件邮件小程序
2018/05/22 Python
python 随机森林算法及其优化详解
2019/07/11 Python
Python基于BeautifulSoup和requests实现的爬虫功能示例
2019/08/02 Python
多版本python的pip 升级后, pip2 pip3 与python版本失配解决方法
2019/09/11 Python
在脚本中单独使用django的ORM模型详解
2020/04/01 Python
String s = new String(“xyz”);创建了几个String Object?
2015/08/05 面试题
2015年女生节活动总结
2015/02/27 职场文书
2015年小学教导处工作总结
2015/05/26 职场文书
小学生手册家长意见
2015/06/03 职场文书
军训阅兵新闻稿
2015/07/17 职场文书
2016年小学生寒假家长评语
2015/10/10 职场文书
python+pytest接口自动化之token关联登录的实现
2022/04/06 Python