成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

使用js callback機制實現調用頁面局部刷新

開發
需求描述:審批表單頁面由我的待辦工作中打開,辦理完畢后希望關閉該頁面并且實現我待辦表格的實時刷新;同時該需求也同樣適用于從某些工作流管理模塊中需要發起審批的情況,比如招聘需求模塊中發起錄用流程;我的績效管理中審批績效等。

需求描述:審批表單頁面由我的待辦工作中打開,辦理完畢后希望關閉該頁面并且實現我待辦表格的實時刷新;同時該需求也同樣適用于從某些工作流管理模塊中需要發起審批的情況,比如招聘需求模塊中發起錄用流程;我的績效管理中審批績效等。

使用js callback機制實現調用頁面局部刷新

我們先來看看之前的實現,該邏輯實現的功能是,從我待辦列表中發起審批,審批結束后直接在當前頁面,也就是審批頁面跳轉至一個新的oa主頁面,并且打開我的工作-我待辦的頁簽,實現方法如下:

  1. $("#but_back").bind("click", function() { 
  2.         window.top.opener=null
  3.         var url = window.location.href; 
  4.         var isoa=url.indexOf('phicomm.com'); 
  5.         //var isoatest=url.indexOf('oatest.phicomm.com'); 
  6.         var curWwwPath=window.document.location.href;  
  7.         var pathName=window.document.location.pathname;  
  8.         var pos=curWwwPath.indexOf(pathName);  
  9.         var localhostPaht=curWwwPath.substring(0,pos);  
  10.         var projectName=pathName.substring(0,pathName.substr(1).indexOf('/')+1); 
  11.         if(isoa>0){ 
  12.             window.top.open(localhostPaht+'/main/index.action?tableName=mywork','_self'); 
  13.         }else
  14.             window.top.open(localhostPaht+projectName+'/main/index.action?tableName=mywork','_self'); 
  15.         } 
  16.     }); 

 

桌面js的處理邏輯:

 

  1. $(document).ready(function($){ 
  2.     // 初始化圖標 
  3.     initModules(initMenus()); 
  4.       
  5.     refixAppPos(); 
  6.     // 注冊事件 
  7.     regClick(); 
  8.       
  9.     sortable(); 
  10.    initIcoRemove(); 
  11.       
  12.     initAppManager(); 
  13.     //解析當前URL判斷是否需要跳轉制定Table 
  14.     gotoTable(); 
  15. }); 
  16.   
  17. //跳轉制定Table 
  18. function gotoTable(){ 
  19.     var tableName = request("tableName"); 
  20.     if(""!=tableName&&null!=tableName&&'undefined'!=tableName){ 
  21.         openUrl($("#desktop_content_icon_"+tableName)); 
  22.     } 

 以上方法雖然實現了辦理結束后跳至我的待辦的功能,但有以下缺陷:

跳轉是在新頁面中,并非在調用頁面,這樣就形成了調用和跳轉頁面兩個相同的桌面;

新的頁面并非與原調用頁面完全一致,調用頁面如打開多個頁簽,新打開的頁面相當于將除我的待辦外的其他頁簽關閉,并不符合用戶的需求;

用戶體驗不友好

我們使用js callback的實現如下,當前頁面的調用頁面非空且未關閉時,我們就直接調用頁面中的js方法實現其局部的刷新。

  1. /** 刷新父窗口關閉彈出窗口 */ 
  2.     function refreshAndClose(){ 
  3.         var jscallback = $.trim($("#jscallback").val()); 
  4.         var type = $.trim($("#type").val()); 
  5.         if (window.opener  && !window.opener.closed && jscallback!=null && jscallback!="") { 
  6.             if(!type){ 
  7.                 //本頁面的調用頁面執行其嵌入或調用的js方法 
  8.                 eval("window.opener."+jscallback+"();"); 
  9.             } 
  10.             window.close();//當前頁面關閉 
  11.         } else { 
  12.             window.top.opener=null
  13.             var url = window.location.href; 
  14.             var isoa=url.indexOf('phicomm.com'); 
  15.               
  16.             var curWwwPath=window.document.location.href;  
  17.             var pathName=window.document.location.pathname;  
  18.             var pos=curWwwPath.indexOf(pathName);  
  19.             var localhostPaht=curWwwPath.substring(0,pos);  
  20.             var projectName=pathName.substring(0,pathName.substr(1).indexOf('/')+1); 
  21.             if(isoa>0){ 
  22.                   
  23.                 window.top.open(localhostPaht+'/main/index.action?tableName=mywork','_self'); 
  24.             }else
  25.                 window.top.open(localhostPaht+projectName+'/main/index.action?tableName=mywork','_self'); 
  26.             } 
  27.         } 
  28.     }

調用頁面js:grid即為需要局部刷新的表格。 

  1. function openUrl(url){ 
  2.     url=url+"&jscallback=callsus" 
  3.          window.open(url,'_blank');    
  4. function callsus(){ 
  5.     $('#performanceDataGrid').reload(); 
  6. }

通過js callback實現了調用頁面的局部刷新,并對其他應用的類似功能具有一定的指導和參考意義。

本文出自 “南湖礦工技術空間” 博客,請務必保留此出處http://jncumter.blog.51cto.com/812546/1623739

責任編輯:王雪燕 來源: 南湖礦工技術空間
相關推薦

2015-10-22 10:59:13

ListViewItem刷新

2009-08-04 14:44:40

callback實現機ASP.NET2.0

2021-09-10 15:13:41

鴻蒙HarmonyOS應用

2015-05-13 09:36:18

js模擬手機下拉刷新

2021-03-12 16:25:17

技巧vue頁面刷新

2010-10-08 12:06:40

聯動菜單JavaScript

2021-06-03 08:03:13

網絡

2012-04-12 10:19:08

Ajax.NET

2017-05-02 22:38:44

前端開發JS事件循環機制

2021-05-05 11:36:31

Node前端自動化熱重載頁面

2023-06-12 15:37:38

鴻蒙ArkUI

2011-07-15 09:57:03

MongoDB緩存刷新

2013-12-02 15:25:38

jQuery插件

2017-04-12 11:46:46

前端瀏覽器渲染機制

2015-11-20 11:20:54

js開發

2021-05-07 09:35:30

鴻蒙HarmonyOS應用

2021-12-08 06:53:28

Choreograph屏幕機制

2021-12-10 00:01:53

Vsync信號機制

2021-06-18 10:12:09

JS代碼前端

2023-12-13 10:07:56

地圖自動駕駛
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 免费观看av | 成人在线观看免费 | 日本免费一区二区三区视频 | 国产精品久久久久久久一区探花 | 久久久影院 | 成人免费看片 | 成人免费一区二区三区视频网站 | 欧美精品一区免费 | av一区在线 | 久久精品视频在线免费观看 | 久久伊人影院 | 色综合久久久久 | 久久久www成人免费无遮挡大片 | 精品欧美一区二区三区久久久 | 国产美女免费视频 | 国产日韩久久 | 日韩在线不卡视频 | 国产午夜精品视频 | 久久免费精品 | 伊人久久麻豆 | 青青草网 | 四虎影视1304t | 成人黄在线观看 | 欧美国产日韩在线观看成人 | 日本超碰在线 | 国产99久久 | 国产a区| 亚洲第一网站 | 99久久亚洲 | 99精品一区 | 我要看一级片 | 国产日韩精品在线 | 久久国内精品 | 作爱视频免费观看 | 欧美一卡二卡在线 | 超碰一区二区 | 中文字幕国产 | av网站免费看| 欧一区| 一区二区三区高清在线观看 | 国产探花在线精品一区二区 |