91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JS如何封裝父頁面子頁面交互接口

發布時間:2021-07-20 14:16:46 來源:億速云 閱讀:132 作者:小新 欄目:web開發

這篇文章主要介紹了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>

感謝你能夠認真閱讀完這篇文章,希望小編分享的“JS如何封裝父頁面子頁面交互接口”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

js
AI

临澧县| 临城县| 新邵县| 邓州市| 石首市| 靖远县| 楚雄市| 客服| 保靖县| 永和县| 三门县| 许昌县| 武鸣县| 林州市| 油尖旺区| 伊金霍洛旗| 陆丰市| 资阳市| 芦溪县| 永福县| 突泉县| 瓦房店市| 安仁县| 东乡族自治县| 山东省| 安溪县| 桃园县| 扎兰屯市| 博湖县| 长丰县| 丰原市| 满城县| 金寨县| 建瓯市| 九江县| 怀宁县| 开原市| 兴安县| 定日县| 离岛区| 淳化县|