common.js 5.3 KB

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