欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

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

這篇文章主要介紹了JS如何封裝父頁面子頁面交互接口,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

站在用戶的角度思考問題,與客戶深入溝通,找到欒城網(wǎng)站設(shè)計與欒城網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗,讓設(shè)計與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:成都網(wǎng)站建設(shè)、網(wǎng)站設(shè)計、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣、主機域名、網(wǎng)頁空間、企業(yè)郵箱。業(yè)務(wù)覆蓋欒城地區(qū)。

定義標(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)閉時,調(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ù)時的回調(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>

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“JS如何封裝父頁面子頁面交互接口”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!

當(dāng)前名稱:JS如何封裝父頁面子頁面交互接口
當(dāng)前鏈接:http://www.aaarwkj.com/article16/pjcsdg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站營銷電子商務(wù)、外貿(mào)網(wǎng)站建設(shè)網(wǎng)站改版、關(guān)鍵詞優(yōu)化、虛擬主機

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站制作
91精品久久久久久| 日本一区二区三区福利视频| 18禁黄网站禁片免费视频| 免费观看黄片视频在线播放| 久久亚洲国产成人精品性色| 18禁在线免费观看网站| 久久国产精品成人av| 免费精品一区二区三区欧美| 国产成人免费视频一区| 传媒精品视频在线观看| 日本欧美三级高潮受不了| 两性色午夜视频免费网站| 午夜影院网站在线看黄| 欧美精品一区二区网址| 久久久这里只有精品99| 五月天丁香婷婷深爱| 免费看夫妻性生活视频| 在线午夜免费视频观看| 秒播视频午夜福利在线观看| 国产日韩欧美亚洲中文| 亚洲伦理一区二区三区中文| 日韩黄片一区二区三区| 可以看的黄色亚洲网站| 亚洲国产欧美日韩在线| 亚洲欧美极品一区色婷婷| 一区二区三区深夜福利| 91九色在线免费观看 | 欧美日韩综合人妻丝袜偷拍 | 亚洲中文乱码一区二区| 中文字幕人妻久久一区| av免费观看一区二区三区| 麻豆乱淫一区二区三爱免费| 欧美成人极品一区二区三区| 黄片小视频在线免费播放| 国产欧美日韩一区二区三区四区| 午夜在线观看成人av| 人妻少妇久久中文字幕韩| 欧美香蕉一区二区视频| 国产三级全黄在线播放| 国产男女免费操作视频| 亚洲精品视频久久偷拍|