common.js 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  1. //公共js,主要做表单验证,以及基本方法封装
  2. const utils = {
  3. isNullOrEmpty: function(value) {
  4. //是否为空
  5. return (value === null || value === '' || value === undefined) ? true : false;
  6. },
  7. trim: function(value) {
  8. //去空格
  9. return value.replace(/(^\s*)|(\s*$)/g, "");
  10. },
  11. isEmail: function(value){
  12. //是否为邮箱
  13. return RegExp(/^([a-zA-Z0-9]+[_|\_|\.]?)*[a-zA-Z0-9]+@([a-zA-Z0-9]+[_|\_|\.]?)*[a-zA-Z0-9]+\.[a-zA-Z]{2,3}$/).test(value);
  14. },
  15. isWebsite: function(value){
  16. //是否为网址
  17. return RegExp(/^((http|ftp|https):\/\/[a-zA-Z0-9]|[a-zA-Z0-9])[-a-zA-Z0-9]{0,62}(.[a-zA-Z0-9][-a-zA-Z0-9]{0,62})+.?$/).test(value);
  18. },
  19. isMobile: function(value) {
  20. //是否为手机号
  21. return RegExp(/^1[1-9][0-9]{9}$/).test(value);
  22. },
  23. isFloat: function(value) {
  24. //金额,只允许保留两位小数
  25. return RegExp(/^([0-9]*[.]?[0-9])[0-9]{0,1}$/).test(value);
  26. },
  27. isNum: function(value) {
  28. //是否全为数字
  29. return RegExp(/^[0-9]+$/).test(value);
  30. },
  31. isEmailCode:function(value) {
  32. return RegExp(/^\d{4}$/).test(value);
  33. },
  34. isMobileCode:function(value) {
  35. return RegExp(/^\d{6}$/).test(value);
  36. },
  37. isCredit:function(value) {//统一社会信用代码
  38. return RegExp(/^[0-9A-HJ-NPQRTUWXY]{2}\\d{6}[0-9A-HJ-NPQRTUWXY]{10}$/).test(value);
  39. },
  40. checkPwd: function(value) {//密码为8~20位数字和字母组合
  41. return RegExp(/^(?![0-9]+$)(?![a-zA-Z]+$)[0-9A-Za-z]{8,16}$/).test(value);
  42. },
  43. isNoChinese: function(value) {//数字和字母组合
  44. return RegExp(/^[A-Za-z0-9]+$/).test(value);
  45. },
  46. hidePhone:function(value) {
  47. return value.replace(/^(\d{3})\d{4}(\d+)/,"$1****$2")
  48. },
  49. interceptHtmlFn: function(value){
  50. return value ? value.replace(/<[^>]+>/g,"") : value
  51. },
  52. desensitizationName:function(value){
  53. if(null != value && value != undefined){
  54. if(value.length <= 3){
  55. let ruten = value.substring(1);
  56. return value.replace(ruten,'**');
  57. } else if(value.length > 3 && value.length <= 6){
  58. let ruten = value.substring(2);
  59. return value.replace(ruten,'**');
  60. }
  61. } else {
  62. return "";
  63. }
  64. },
  65. formatNum: function(num) {
  66. //格式化手机号码
  67. if (utils.isMobile(num)) {
  68. num = num.replace(/^(\d{3})\d{4}(\d{4})$/, '$1****$2')
  69. }
  70. return num;
  71. },
  72. rmoney: function(money) {
  73. //金额格式化
  74. return parseFloat(money).toFixed(2).toString().split('').reverse().join('').replace(/(\d{3})/g, '$1,').replace(
  75. /\,$/, '').split('').reverse().join('');
  76. },
  77. bankRegex:function(num){
  78. let bankNum = ''
  79. bankNum = num.replace(/\D/g, '').replace(/(....)(?=.)/g, '$1 ');
  80. return bankNum
  81. },
  82. checkData:function(value){
  83. let data;
  84. if(value == null || value ==""){
  85. data = ''
  86. }else{
  87. data = value
  88. }
  89. return data
  90. },
  91. formatDate: function(formatStr, fdate) {
  92. //日期格式化
  93. if (fdate) {
  94. if (~fdate.indexOf('.')) {
  95. fdate = fdate.substring(0, fdate.indexOf('.'));
  96. }
  97. fdate = fdate.toString().replace('T', ' ').replace(/\-/g, '/');
  98. var fTime, fStr = 'ymdhis';
  99. if (!formatStr)
  100. formatStr = "y-m-d h:i:s";
  101. if (fdate)
  102. fTime = new Date(fdate);
  103. else
  104. fTime = new Date();
  105. var month = fTime.getMonth() + 1;
  106. var day = fTime.getDate();
  107. var hours = fTime.getHours();
  108. var minu = fTime.getMinutes();
  109. var second = fTime.getSeconds();
  110. month = month < 10 ? '0' + month : month;
  111. day = day < 10 ? '0' + day : day;
  112. hours = hours < 10 ? ('0' + hours) : hours;
  113. minu = minu < 10 ? '0' + minu : minu;
  114. second = second < 10 ? '0' + second : second;
  115. var formatArr = [
  116. fTime.getFullYear().toString(),
  117. month.toString(),
  118. day.toString(),
  119. hours.toString(),
  120. minu.toString(),
  121. second.toString()
  122. ]
  123. for (var i = 0; i < formatArr.length; i++) {
  124. formatStr = formatStr.replace(fStr.charAt(i), formatArr[i]);
  125. }
  126. return formatStr;
  127. } else {
  128. return "";
  129. }
  130. },
  131. throttle: function(fn, gapTime) {
  132. if (gapTime == null || gapTime == undefined) {
  133. gapTime = 1500
  134. }
  135. let _lastTime = null
  136. // 返回新的函数
  137. return function () {
  138. let _nowTime = +new Date()
  139. if (_nowTime - _lastTime > gapTime || !_lastTime) {
  140. fn.apply(this, arguments) //将this和参数传给原函数
  141. _lastTime = _nowTime
  142. }
  143. }
  144. },
  145. debounce: function(fn, delay, isImmediate) {
  146. var timer = null; //初始化timer,作为计时清除依据
  147. return function() {
  148. var context = this; //获取函数所在作用域this
  149. var args = arguments; //取得传入参数
  150. clearTimeout(timer);
  151. if(isImmediate && timer === null) {
  152. //时间间隔外立即执行
  153. fn.apply(context,args);
  154. timer = 0;
  155. return;
  156. }
  157. timer = setTimeout(function() {
  158. fn.apply(context,args);
  159. timer = null;
  160. }, delay);
  161. }
  162. }
  163. }
  164. module.exports = {
  165. isNullOrEmpty: utils.isNullOrEmpty,
  166. trim: utils.trim,
  167. isMobile: utils.isMobile,
  168. isEmail: utils.isEmail,
  169. isWebsite:utils.isWebsite,
  170. isFloat: utils.isFloat,
  171. isNum: utils.isNum,
  172. isEmailCode:utils.isEmailCode,
  173. isMobileCode:utils.isMobileCode,
  174. isNoChinese:utils.isNoChinese,
  175. checkPwd: utils.checkPwd,
  176. formatNum:utils.formatNum,
  177. rmoney: utils.rmoney,
  178. formatDate: utils.formatDate,
  179. bankRegex: utils.bankRegex,
  180. checkData:utils.checkData,
  181. hidePhone:utils.hidePhone,
  182. interceptHtmlFn:utils.interceptHtmlFn,
  183. desensitizationName:utils.desensitizationName,
  184. throttle: utils.throttle,
  185. debounce: utils.debounce
  186. }