js 封装父页面子页面交互接口

定义标准接口

 Interface= {};
 Interface.ParentWin = {};
 Interface.ChildWin = {};

 /**
  * 父页面提供的标准接口函数名称
  */
 Interface.ParentWin.funName = {
     getDataFun: "getDataFun", //子页面调用,提供给子页面的数据接口
     updateDataFun: "updateDataFun", //子页面调用,向父页面提交数据接口
     closeFun: "closeFun" //子页面需要关闭时,调用父页面的关闭窗口接口
 }

 /**
  * 父页面设置需要提供给子页面的接口函数
  * @param childWinId :要使用的子页面对应接口的id,该id需要与子页面中定义的id一致
  * @param functionName  : 需要注册的回调函数名称,接口名称只能是Interface.ParentWin.funName中定义的名称
  * @param callbackFun :子页面数据向父页面更新数据时的回调函数,接口入参为js对象
  */
 Interface.ParentWin.setFunForChild = function(childWinId, functionName, callbackFun) {
     if (comm.isEmpty(childWinId)) {
         alert("没有为子页面调用接口定义对象Id");
         return;
     }
     //保存父页面提供给子页面调用的接口总对象
     if (comm.isEmpty(window.childCallbackObj)) {
         window.childCallbackObj = {};
     }
     //与指定子页面对应的回调接口对象
     var childCallbackObj = window.childCallbackObj;
     if (comm.isEmpty(childCallbackObj[childWinId])) {
         childCallbackObj[childWinId] = {};
     }

     var childObj = childCallbackObj[childWinId];
     if (!comm.isEmpty(childObj[functionName])) {
         alert("子页面" + childWinId + " 所需调用接口已存在" + functionName);
         return;
     }
     //检查接口是否为注册的接口
     for (var pro in Interface.ParentWin.funName) {
         if (Interface.ParentWin.funName[pro] == functionName) {
             childObj[functionName] = callbackFun;
             return;
         }
     }
     alert("子页面 " + childWinId + " 所需调用接口未注册:" + functionName + "。请检查接口定义声明对象。");
 }

 /**
  * 检查指定的子页面调用接口是否存在
  */
 Interface.ChildWin.checkValid = function(childWinId, funName) {
     var parentWin = window.parent;
     var childCallbackObj = parentWin.childCallbackObj;
     if (comm.isEmpty(childWinId)) {
         alert("子页面调用接口定义对象Id不能为空!");
         return false;
     }
     if (comm.isEmpty(childCallbackObj)) {
         alert("父页面调用接口定义的对象不存在");
         return false;
     }
     var childObj = childCallbackObj[childWinId];
     if (comm.isEmpty(childObj)) {
         alert("子页面调用接口定义的对象不存在");
         return false;
     }
     if (comm.isEmpty(childObj[funName])) {
         alert("父页面调用接口定义不存在:" + funName);
         return false;
     }
     return true;
 }

 /**
  * 子页面调用父页面的接口函数
  * @childWinId :子页面定义的自身页面Id
  * @funcName : 需要调用的回调函数名称
  * @params :  需要传递的参数
  * @return :如果函数有返回值则通过其进行返回
  */
 Interface.ChildWin.callBack = function(childWinId, funcName, params) {
     if (!Interface.ChildWin.checkValid(childWinId, funcName)) {
         return;
     }

     var parentWin = window.parent;
     var childObj = parentWin.childCallbackObj[childWinId];
     return childObj[funcName].call(parentWin, params);
 }

demo

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title>父页面</title>
    </head>
    <body>

        <script src="js/common.js"></script>
        <script>
            //传给子页面的值
            Interface.ParentWin.setFunForChild("data", Interface.ParentWin.funName.getDataFun, function() {
                return value;
            });

            //获取子页面函数并调用
            window.fun;
            Interface.ParentWin.setFunForChild("test",Interface.ParentWin.funName.updateDataFun,function(param){
                fun = param;
            });

            //调用
            var val = fun("1111");
            console.log(val);
        </script>
    </body>
</html>
<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title>子页面</title>
    </head>
    <body>
        <script src="js/common.js"></script>
        <script>

            //父页面传入数据
            var data = Interface.ChildWin.callBack("data", Interface.ParentWin.funName.getDataFun);
            console.log(data);

            //提供给父页面调用的函数
            Interface.ChildWin.callBack("test",Interface.ParentWin.funName.updateDataFun,function(data){
                alert(data);
                var str = "xxx";
                return str;
            });

        </script>
    </body>
</html>

原文地址:https://www.cnblogs.com/xiaoqiuzhang/p/11082195.html

时间: 2024-11-09 09:21:26

js 封装父页面子页面交互接口的相关文章

javascript父、子页面交互小结

帧用来存放子页面,既可以是iframe,又可以是frameset.window对象是全局对象,页面上的一切函数和对象都在它的作用域里.     1.parent代表父窗口.如果父窗口又存在若干层嵌套,则top代表顶级父窗口. self代表窗口自身. Java代码   if(self==top){//}判断窗口是否处于顶级 if(self==parent){}//也可以 2.1.父页面访问子页面元素.思路是子页面的元素都在其window.document对象里面,先获取它然后就好说了.     

js+html+css实现简单页面交互功能(2015知乎前端笔试题)http://v.youku.com/v_show/id_XMTI0ODQ5NTAyOA==.html?from=y1.7-1.2

js+html+css实现简单页面交互功能(2015知乎前端笔试题) http://v.youku.com/v_show/id_XMTI0ODQ5NTAyOA==.html?from=y1.7-1.2 密码:hellozhihu

iframe子页面js调用父页面js函数/父页面调用Iframe子页面中js方法

1.假设当前页面为a.html, iframe的src页面为b.html,其代码如下: 1 <span class="tag"><html> 2 <br></span><span class="tag"><head> 3 <br></span><span class="tag"><title></span><s

js里父页面与子页面的相互调用

(原文地址:http://blog.sina.com.cn/s/blog_8089e3810101464f.html) 一.在页面里用 open 打开的子页面: 1.子页面调用父页面的方法,包括子页面给父页面传值: window.opener.methodName(); window.opener.methodName(param1,param2); 2.父页面关闭子页面:在父页面 openWin=window.open(""); function bClick(){ openWin.

python第五十四天 javascript语法 1.运算符 2. 流程控制 3. 函数 4. 四种变量 5. 数据类型的运用 6. js页面交互

1.运算符 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> </body> <script> let n1 = 5; let n2 = 2; let res = n1 / n2; console.log(res); // 将数字转换成整数,

用jQuery基于原生js封装的轮播

我发现轮播在很多网站里面都用到过,一个绚丽的轮播可以为网页增色不少,最近闲来无事,也用原生js封装了一个轮播,可能不像网上的插件那么炫,但是也有用心去做.主要用了闭包的思想.需要传递的参数有:图片地址的数组,图片宽度,上一页,下一页的id,图片列表即ul的id(这儿使用无序列表排列的图片),自动轮播间隔的时间.功能:实现了轮播的自动轮播,可以点击上一页,下一页进行切换. 下面是html中的代码,只需要把存放的容器写好,引入jquery即可: <!DOCTYPE html><html>

【转】JavaScript实际应用:父子页面交互

转自:http://blog.csdn.net/xinyueyuli/article/details/509893 最近项目开发中需要子窗口和父窗口交互的内容,基本上无非就是把子窗口的信息传递给父窗口,并且关闭自己等等,或者是父窗口把自己的信息传递给子窗口等等. 1.父窗口传递信息给子窗口 看代码实例: <script language=javascript> function outPut() { //获取父窗口的文本信息赋值给text var text = document.abc.tex

(基础篇)PHP与Web页面交互

PHP与Web页面交互是实现PHP网站与用户交互的重要手段.在PHP中提供了两种与Web页面交互的方法,一种是通过Web表单提交数据,另一种是通过URL参数传递. 这里我们将详细讲解表单的相关知识,为以后学习PHP页面交互做好铺垫. 1 .创建表单 Web表单的功能是让浏览者和网站有一个互动的平台.Web表单主要用来在网页中发送数据到服务器,如提交注册信息时需要使用表单.当用户填写完信息后执行提交(submit)操作,于是将表单中的数据从客户端的浏览器传送到服务器端,经过服务器端PHP程序进行处

js在一定时间内跳转页面及各种页面刷新

1.js 代码: <SCRIPT LANGUAGE="JavaScript"> var time = 5; //时间,秒 var timelong = 0; function diplaytime(){ //时间递减 document.all.his.innerHTML = time -timelong ; timelong ++; } function redirect(){ //跳转页 //history.back(); window.location.href=&qu