syUtil.js 9.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375
  1. /**
  2. * @author 孙宇
  3. *
  4. * @requires jQuery,EasyUI
  5. *
  6. * panel关闭时回收内存,主要用于layout使用iframe嵌入网页时的内存泄漏问题
  7. */
  8. $.fn.panel.defaults.onBeforeDestroy = function() {
  9. var frame = $('iframe', this);
  10. try {
  11. if (frame.length > 0) {
  12. for ( var i = 0; i < frame.length; i++) {
  13. frame[i].contentWindow.document.write('');
  14. frame[i].contentWindow.close();
  15. }
  16. frame.remove();
  17. if ($.browser.msie) {
  18. CollectGarbage();
  19. }
  20. }
  21. } catch (e) {
  22. }
  23. };
  24. /**
  25. * 使panel和datagrid在加载时提示
  26. *
  27. * @author 孙宇
  28. *
  29. * @requires jQuery,EasyUI
  30. *
  31. */
  32. $.fn.panel.defaults.loadingMessage = '加载中....';
  33. $.fn.datagrid.defaults.loadMsg = '加载中....';
  34. /**
  35. * @author 孙宇
  36. *
  37. * @requires jQuery,EasyUI
  38. *
  39. * 通用错误提示
  40. *
  41. * 用于datagrid/treegrid/tree/combogrid/combobox/form加载数据出错时的操作
  42. */
  43. var easyuiErrorFunction = function(XMLHttpRequest) {
  44. $.messager.progress('close');
  45. try{
  46. var emsg = XMLHttpRequest.responseText.substring(XMLHttpRequest.responseText.indexOf('错误描述'),XMLHttpRequest.responseText.indexOf('错误信息'));
  47. $.messager.alert('错误',emsg);
  48. }catch(ex){
  49. $.messager.alert('错误',XMLHttpRequest.responseText+'');
  50. }
  51. };
  52. $.fn.datagrid.defaults.onLoadError = easyuiErrorFunction;
  53. $.fn.treegrid.defaults.onLoadError = easyuiErrorFunction;
  54. $.fn.tree.defaults.onLoadError = easyuiErrorFunction;
  55. $.fn.combogrid.defaults.onLoadError = easyuiErrorFunction;
  56. $.fn.combobox.defaults.onLoadError = easyuiErrorFunction;
  57. $.fn.form.defaults.onLoadError = easyuiErrorFunction;
  58. /**
  59. * @author 孙宇
  60. *
  61. * @requires jQuery,EasyUI
  62. *
  63. * 为datagrid、treegrid增加表头菜单,用于显示或隐藏列,注意:冻结列不在此菜单中
  64. */
  65. var createGridHeaderContextMenu = function(e, field) {
  66. e.preventDefault();
  67. var grid = $(this);/* grid本身 */
  68. var headerContextMenu = this.headerContextMenu;/* grid上的列头菜单对象 */
  69. if (!headerContextMenu) {
  70. var tmenu = $('<div style="width:100px;"></div>').appendTo('body');
  71. var fields = grid.datagrid('getColumnFields');
  72. console.log('id='+grid.attr('id'));
  73. storage=$.localStorage;if(!storage)storage=$.cookieStorage;
  74. var cols = storage.get(grid.attr('id')+'hiddenColumns');
  75. var init=true;
  76. if(cols){
  77. init=false;
  78. }
  79. for ( var i = 0; i < fields.length; i++) {
  80. var fildOption = grid.datagrid('getColumnOption', fields[i]);
  81. console.log(fields[i]+'='+fildOption.hidden);
  82. if (!fildOption.hidden||fildOption.hidden==false) {
  83. $('<div iconCls="icon-ok" field="' + fields[i] + '"/>').html(fildOption.title).appendTo(tmenu);
  84. } else {
  85. if(init==false){
  86. for(var j=0;j<cols.length;j++){
  87. if(cols[j].field==fields[i]&&cols[j].visible!=false){
  88. //console.log(cols[j].field+'=='+cols[j].visible);
  89. $('<div iconCls="icon-empty" field="' + fields[i] + '"/>').html(fildOption.title).appendTo(tmenu);
  90. }
  91. }
  92. }
  93. }
  94. }saveHeader();//龙金波,修改bug 先存一个表头的hidden初始状态,避免隐藏字段第一次保存时就不对了
  95. headerContextMenu = this.headerContextMenu = tmenu.menu({
  96. onClick : function(item) {
  97. var field = $(item.target).attr('field');
  98. if (item.iconCls == 'icon-ok') {
  99. grid.datagrid('hideColumn', field);
  100. $(this).menu('setIcon', {
  101. target : item.target,
  102. iconCls : 'icon-empty'
  103. });saveHeader(field,true);//龙金波添加保存表头
  104. } else if (item.iconCls == 'icon-empty') {
  105. grid.datagrid('showColumn', field);
  106. $(this).menu('setIcon', {
  107. target : item.target,
  108. iconCls : 'icon-ok'
  109. });saveHeader(field,false);//龙金波添加保存表头
  110. }else{
  111. //恢复表头
  112. }
  113. }
  114. });
  115. }
  116. headerContextMenu.menu('show', {
  117. left : e.pageX,
  118. top : e.pageY
  119. });
  120. };
  121. $.fn.datagrid.defaults.onHeaderContextMenu = createGridHeaderContextMenu;
  122. $.fn.treegrid.defaults.onHeaderContextMenu = createGridHeaderContextMenu;
  123. /**
  124. * @author 孙宇
  125. *
  126. * @requires jQuery,EasyUI
  127. *
  128. * 扩展validatebox,添加验证两次密码功能
  129. */
  130. $.extend($.fn.validatebox.defaults.rules, {
  131. eqPwd : {
  132. validator : function(value, param) {
  133. return value == $(param[0]).val();
  134. },
  135. message : '密码不一致!'
  136. }
  137. });
  138. /**
  139. * @author 夏悸
  140. *
  141. * @requires jQuery,EasyUI
  142. *
  143. * 扩展tree,使其支持平滑数据格式
  144. */
  145. $.fn.tree.defaults.loadFilter = function(data, parent) {
  146. var opt = $(this).data().tree.options;
  147. var idFiled, textFiled, parentField;
  148. if (opt.parentField) {
  149. idFiled = opt.idFiled || 'id';
  150. textFiled = opt.textFiled || 'text';
  151. parentField = opt.parentField;
  152. var i, l, treeData = [], tmpMap = [];
  153. for (i = 0, l = data.length; i < l; i++) {
  154. tmpMap[data[i][idFiled]] = data[i];
  155. }
  156. for (i = 0, l = data.length; i < l; i++) {
  157. if (tmpMap[data[i][parentField]] && data[i][idFiled] != data[i][parentField]) {
  158. if (!tmpMap[data[i][parentField]]['children'])
  159. tmpMap[data[i][parentField]]['children'] = [];
  160. data[i]['text'] = data[i][textFiled];
  161. tmpMap[data[i][parentField]]['children'].push(data[i]);
  162. } else {
  163. data[i]['text'] = data[i][textFiled];
  164. treeData.push(data[i]);
  165. }
  166. }
  167. return treeData;
  168. }
  169. return data;
  170. };
  171. /**
  172. * @author 孙宇
  173. *
  174. * @requires jQuery,EasyUI
  175. *
  176. * 扩展treegrid,使其支持平滑数据格式
  177. */
  178. $.fn.treegrid.defaults.loadFilter = function(data, parentId) {
  179. var opt = $(this).data().treegrid.options;
  180. var idFiled, textFiled, parentField;
  181. if (opt.parentField) {
  182. idFiled = opt.idFiled || 'id';
  183. textFiled = opt.textFiled || 'text';
  184. parentField = opt.parentField;
  185. var i, l, treeData = [], tmpMap = [];
  186. for (i = 0, l = data.length; i < l; i++) {
  187. tmpMap[data[i][idFiled]] = data[i];
  188. }
  189. for (i = 0, l = data.length; i < l; i++) {
  190. if (tmpMap[data[i][parentField]] && data[i][idFiled] != data[i][parentField]) {
  191. if (!tmpMap[data[i][parentField]]['children'])
  192. tmpMap[data[i][parentField]]['children'] = [];
  193. data[i]['text'] = data[i][textFiled];
  194. tmpMap[data[i][parentField]]['children'].push(data[i]);
  195. } else {
  196. data[i]['text'] = data[i][textFiled];
  197. treeData.push(data[i]);
  198. }
  199. }
  200. return treeData;
  201. }
  202. return data;
  203. };
  204. /**
  205. * @author 孙宇
  206. *
  207. * @requires jQuery,EasyUI
  208. *
  209. * 扩展combotree,使其支持平滑数据格式
  210. */
  211. $.fn.combotree.defaults.loadFilter = $.fn.tree.defaults.loadFilter;
  212. /**
  213. * @author 孙宇
  214. *
  215. * @requires jQuery,EasyUI
  216. *
  217. * 防止panel/window/dialog组件超出浏览器边界
  218. * @param left
  219. * @param top
  220. */
  221. var easyuiPanelOnMove = function(left, top) {
  222. var l = left;
  223. var t = top;
  224. if (l < 1) {
  225. l = 1;
  226. }
  227. if (t < 1) {
  228. t = 1;
  229. }
  230. var width = parseInt($(this).parent().css('width')) + 14;
  231. var height = parseInt($(this).parent().css('height')) + 14;
  232. var right = l + width;
  233. var buttom = t + height;
  234. var browserWidth = $(window).width();
  235. var browserHeight = $(window).height();
  236. if (right > browserWidth) {
  237. l = browserWidth - width;
  238. }
  239. if (buttom > browserHeight) {
  240. t = browserHeight - height;
  241. }
  242. $(this).parent().css({/* 修正面板位置 */
  243. left : l,
  244. top : t
  245. });
  246. };
  247. $.fn.dialog.defaults.onMove = easyuiPanelOnMove;
  248. $.fn.window.defaults.onMove = easyuiPanelOnMove;
  249. $.fn.panel.defaults.onMove = easyuiPanelOnMove;
  250. /**
  251. * @author 孙宇
  252. *
  253. * @requires jQuery,EasyUI,jQuery cookie plugin
  254. *
  255. * 更换EasyUI主题的方法
  256. *
  257. * @param themeName
  258. * 主题名称
  259. */
  260. changeTheme = function(themeName) {
  261. var $easyuiTheme = $('#easyuiTheme');
  262. var url = $easyuiTheme.attr('href');
  263. var href = url.substring(0, url.indexOf('themes')) + 'themes/' + themeName + '/easyui.css';
  264. $easyuiTheme.attr('href', href);
  265. var $iframe = $('iframe');
  266. if ($iframe.length > 0) {
  267. for ( var i = 0; i < $iframe.length; i++) {
  268. var ifr = $iframe[i];
  269. $(ifr).contents().find('#easyuiTheme').attr('href', href);
  270. }
  271. }
  272. $.cookie('easyuiThemeName', themeName, {
  273. expires : 7
  274. });
  275. };
  276. /**
  277. * @author 孙宇
  278. *
  279. * @requires jQuery
  280. *
  281. * 将form表单元素的值序列化成对象
  282. *
  283. * @returns object
  284. */
  285. serializeObject = function(form) {
  286. var o = {};
  287. $.each(form.serializeArray(), function(index) {
  288. if (o[this['name']]) {
  289. o[this['name']] = o[this['name']] + "," + this['value'];
  290. } else {
  291. o[this['name']] = this['value'];
  292. }
  293. });
  294. return o;
  295. };
  296. /**
  297. * @author 孙宇
  298. *
  299. * 增加formatString功能
  300. *
  301. * 使用方法:formatString('字符串{0}字符串{1}字符串','第一个变量','第二个变量');
  302. *
  303. * @returns 格式化后的字符串
  304. */
  305. formatString = function(str) {
  306. for ( var i = 0; i < arguments.length - 1; i++) {
  307. str = str.replace("{" + i + "}", arguments[i + 1]);
  308. }
  309. return str;
  310. };
  311. /**
  312. * @author 孙宇
  313. *
  314. * 接收一个以逗号分割的字符串,返回List,list里每一项都是一个字符串
  315. *
  316. * @returns list
  317. */
  318. stringToList = function(value) {
  319. if (value != undefined && value != '') {
  320. var values = [];
  321. var t = value.split(',');
  322. for ( var i = 0; i < t.length; i++) {
  323. values.push('' + t[i]);/* 避免他将ID当成数字 */
  324. }
  325. return values;
  326. } else {
  327. return [];
  328. }
  329. };
  330. /**
  331. * @author 孙宇
  332. *
  333. * @requires jQuery
  334. *
  335. * 改变jQuery的AJAX默认属性和方法
  336. */
  337. $.ajaxSetup({
  338. type : 'POST',
  339. error : function(XMLHttpRequest, textStatus, errorThrown) {
  340. $.messager.progress('close');
  341. $.messager.alert('错误', XMLHttpRequest.responseText);
  342. }
  343. });
  344. function clearLocalstorage(){
  345. storage=$.localStorage;
  346. if(!storage)
  347. storage=$.cookieStorage;
  348. storage.removeAll();
  349. $.messager.alert('信息', "浏览器缓存清除成功!");
  350. }
  351. //update-begin--Author:钟世云 Date:20150610 for:online支持树配置--------------------
  352. //如果在最外层页面,创建tools对象
  353. if (window.top == window) {
  354. var tools = {msg : "这是一个工具对象,可以把常用属性放到这个对象上。如:在任意页面用top.currDatagri可以获取当前的datagrid"};
  355. }
  356. //update-end--Author:钟世云 Date:20150610 for:online支持树配置----------------------