helper.js 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. 'use strict';
  2. /**
  3. * 辅助方法扩展
  4. *
  5. * @author CaiAoLin
  6. * @date 2017/9/28
  7. * @version
  8. */
  9. module.exports = {
  10. /**
  11. * 内置验证器转换为前端jquery验证器
  12. *
  13. * @param {Object} rule - 后端service中的rule
  14. * @return {Object} - 返回转换后的数据
  15. */
  16. validateConvert(rule) {
  17. const result = {};
  18. if (Object.keys(rule).length <= 0) {
  19. return rule;
  20. }
  21. for (const index in rule) {
  22. result[index] = {};
  23. const type = rule[index].type !== undefined && rule[index].type !== '' ? rule[index].type : '';
  24. const stringType = ['string', 'password'];
  25. // 是否必填
  26. if (rule[index].required !== undefined) {
  27. result[index].required = rule[index].required;
  28. }
  29. // 最小长度
  30. if (stringType.indexOf(type) >= 0 && rule[index].min !== undefined) {
  31. result[index].minlength = rule[index].min;
  32. }
  33. // 最大长度
  34. if (stringType.indexOf(type) >= 0 && rule[index].max !== undefined) {
  35. result[index].maxlength = rule[index].max;
  36. }
  37. // 密码相关
  38. if (type === 'password' && rule[index].compare !== undefined) {
  39. result[index].equalTo = '#' + rule[index].compare;
  40. }
  41. // 最小值
  42. const integerType = ['integer', 'int', 'Number'];
  43. if (integerType.indexOf(type) >= 0 && rule[index].min !== undefined) {
  44. result[index].min = rule[index].min;
  45. }
  46. // 最大值
  47. if (integerType.indexOf(type) >= 0 && rule[index].max !== undefined) {
  48. result[index].max = rule[index].max;
  49. }
  50. // 自定义判断
  51. const customType = ['mobile', 'ip'];
  52. // 自定义且带参数
  53. if (customType.indexOf(type) >= 0) {
  54. result[index][type] = true;
  55. if (rule[index].allowEmpty !== undefined) {
  56. result[index].required = !rule[index].allowEmpty;
  57. }
  58. }
  59. }
  60. return result;
  61. },
  62. /**
  63. * 生成随机字符串
  64. *
  65. * @param {Number} length - 需要生成字符串的长度
  66. * @param {Number} type - 1为数字和字符 2为纯数字 3为纯字母
  67. * @return {String} - 返回生成结果
  68. */
  69. generateRandomString(length, type = 1) {
  70. length = parseInt(length);
  71. length = isNaN(length) ? 1 : length;
  72. let randSeed = [];
  73. let numberSeed = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9];
  74. let stringSeed = ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S',
  75. 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o',
  76. 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z'];
  77. switch (type) {
  78. case 1:
  79. randSeed = stringSeed.concat(numberSeed);
  80. stringSeed = numberSeed = null;
  81. break;
  82. case 2:
  83. randSeed = numberSeed;
  84. break;
  85. case 3:
  86. randSeed = stringSeed;
  87. break;
  88. default:
  89. break;
  90. }
  91. const seedLength = randSeed.length - 1;
  92. let result = '';
  93. for (let i = 0; i < length; i++) {
  94. const index = Math.ceil(Math.random() * seedLength);
  95. result += randSeed[index];
  96. }
  97. return result;
  98. },
  99. /**
  100. * 显示排序符号
  101. *
  102. * @param {String} field - 字段名称
  103. * @return {String} - 返回字段排序的符号
  104. */
  105. showSortFlag(field) {
  106. const sort = this.ctx.sort;
  107. if (!(sort instanceof Array) || sort.length !== 2) {
  108. return '';
  109. }
  110. sort[1] = sort[1].toUpperCase();
  111. return (sort[0] === field && sort[1] === 'DESC') ? '' : '-';
  112. },
  113. /**
  114. * 判断是否为ajax请求
  115. *
  116. * @param {Object} request - 请求数据
  117. * @return {boolean} 判断结果
  118. */
  119. isAjax(request) {
  120. let headerInfo = request.headers['x-requested-with'] === undefined ? '' : request.headers['x-requested-with'];
  121. headerInfo = headerInfo.toLowerCase();
  122. return headerInfo === 'xmlhttprequest';
  123. },
  124. /**
  125. * 模拟发送请求
  126. *
  127. * @param {String} url - 请求地址
  128. * @param {Object} data - 请求数据
  129. * @param {String} type - 请求类型(POST) POST | GET
  130. * @return {Object} - 请求结果
  131. */
  132. async sendRequest(url, data, type = 'POST') {
  133. // 发起请求
  134. const response = await this.ctx.curl(url, {
  135. method: type,
  136. data,
  137. dataType: 'json',
  138. });
  139. if (response.status !== 200) {
  140. throw '请求失败';
  141. }
  142. return response.data;
  143. },
  144. };