JS 封裝父頁面子頁面交互接口的實(shí)例代碼
定義標(biāo)準(zhǔn)接口
Interface= {}; Interface.ParentWin = {}; Interface.ChildWin = {}; /** * 父頁面提供的標(biāo)準(zhǔn)接口函數(shù)名稱 */ Interface.ParentWin.funName = { getDataFun: "getDataFun", //子頁面調(diào)用,提供給子頁面的數(shù)據(jù)接口 updateDataFun: "updateDataFun", //子頁面調(diào)用,向父頁面提交數(shù)據(jù)接口 closeFun: "closeFun" //子頁面需要關(guān)閉時(shí),調(diào)用父頁面的關(guān)閉窗口接口 } /** * 父頁面設(shè)置需要提供給子頁面的接口函數(shù) * @param childWinId :要使用的子頁面對應(yīng)接口的id,該id需要與子頁面中定義的id一致 * @param functionName : 需要注冊的回調(diào)函數(shù)名稱,接口名稱只能是Interface.ParentWin.funName中定義的名稱 * @param callbackFun :子頁面數(shù)據(jù)向父頁面更新數(shù)據(jù)時(shí)的回調(diào)函數(shù),接口入?yún)閖s對象 */ Interface.ParentWin.setFunForChild = function(childWinId, functionName, callbackFun) { if (comm.isEmpty(childWinId)) { alert("沒有為子頁面調(diào)用接口定義對象Id"); return; } //保存父頁面提供給子頁面調(diào)用的接口總對象 if (comm.isEmpty(window.childCallbackObj)) { window.childCallbackObj = {}; } //與指定子頁面對應(yīng)的回調(diào)接口對象 var childCallbackObj = window.childCallbackObj; if (comm.isEmpty(childCallbackObj[childWinId])) { childCallbackObj[childWinId] = {}; } var childObj = childCallbackObj[childWinId]; if (!comm.isEmpty(childObj[functionName])) { alert("子頁面" + childWinId + " 所需調(diào)用接口已存在" + functionName); return; } //檢查接口是否為注冊的接口 for (var pro in Interface.ParentWin.funName) { if (Interface.ParentWin.funName[pro] == functionName) { childObj[functionName] = callbackFun; return; } } alert("子頁面 " + childWinId + " 所需調(diào)用接口未注冊:" + functionName + "。請檢查接口定義聲明對象。"); } /** * 檢查指定的子頁面調(diào)用接口是否存在 */ Interface.ChildWin.checkValid = function(childWinId, funName) { var parentWin = window.parent; var childCallbackObj = parentWin.childCallbackObj; if (comm.isEmpty(childWinId)) { alert("子頁面調(diào)用接口定義對象Id不能為空!"); return false; } if (comm.isEmpty(childCallbackObj)) { alert("父頁面調(diào)用接口定義的對象不存在"); return false; } var childObj = childCallbackObj[childWinId]; if (comm.isEmpty(childObj)) { alert("子頁面調(diào)用接口定義的對象不存在"); return false; } if (comm.isEmpty(childObj[funName])) { alert("父頁面調(diào)用接口定義不存在:" + funName); return false; } return true; } /** * 子頁面調(diào)用父頁面的接口函數(shù) * @childWinId :子頁面定義的自身頁面Id * @funcName : 需要調(diào)用的回調(diào)函數(shù)名稱 * @params : 需要傳遞的參數(shù) * @return :如果函數(shù)有返回值則通過其進(jìn)行返回 */ 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; }); //獲取子頁面函數(shù)并調(diào)用 window.fun; Interface.ParentWin.setFunForChild("test",Interface.ParentWin.funName.updateDataFun,function(param){ fun = param; }); //調(diào)用 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> //父頁面?zhèn)魅霐?shù)據(jù) var data = Interface.ChildWin.callBack("data", Interface.ParentWin.funName.getDataFun); console.log(data); //提供給父頁面調(diào)用的函數(shù) Interface.ChildWin.callBack("test",Interface.ParentWin.funName.updateDataFun,function(data){ alert(data); var str = "xxx"; return str; }); </script> </body> </html>
總結(jié)
以上所述是小編給大家介紹的JS 封裝父頁面子頁面交互接口的實(shí)例代碼,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時(shí)回復(fù)大家的!
相關(guān)文章
JS基于Location實(shí)現(xiàn)訪問Url、重定向及刷新頁面的方法分析
這篇文章主要介紹了JS基于Location實(shí)現(xiàn)訪問Url、重定向及刷新頁面的方法,結(jié)合實(shí)例形式分析了javascript使用Location進(jìn)行URL訪問、重定向、頁面刷新等操作相關(guān)原理、操作技巧與注意事項(xiàng),需要的朋友可以參考下2018-12-12JS表格組件神器bootstrap table詳解(基礎(chǔ)版)
這篇文章主要介紹了JS表格組件神器bootstrap table,bootstrap table界面采用扁平化的風(fēng)格,用戶體驗(yàn)比較好,更好兼容各種客戶端,需要了解更多bootstrap table的朋友可以參考下2015-12-12javascript IE中的DOM ready應(yīng)用技巧
當(dāng)我們想在頁面加載之后執(zhí)行某個(gè)函數(shù),肯定會想到onload了 但onload在瀏覽器看來,就是頁面上的東西全部都加載完畢后才能發(fā)生,但那就為時(shí)已晚了。2008-07-07JavaScript實(shí)現(xiàn)簡易計(jì)算器小功能
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)簡易計(jì)算器小功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-10-10解決typescript項(xiàng)目報(bào)錯(cuò):找不到模塊“xxx”或其相應(yīng)的類型聲明問題
這篇文章主要介紹了解決typescript項(xiàng)目報(bào)錯(cuò):找不到模塊“xxx”或其相應(yīng)的類型聲明問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06javascript實(shí)現(xiàn)的動(dòng)態(tài)添加表單元素input,button等(appendChild)
這篇文章給大家介紹了javascript實(shí)現(xiàn)的動(dòng)態(tài)添加表單元素input,button等(appendChild)的實(shí)例代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2007-11-11