util.js 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413
  1. //工具类
  2. let util = {}
  3. //复制
  4. util.copy=content=>{
  5. uni.setClipboardData({ data: content });
  6. }
  7. //预览图片
  8. // this.$util.preview('http://....png')
  9. // this.$util.$preview('../../test.png')
  10. // this.$util.$preview(['http://....png', '../../test.png'])
  11. util.preview=async (src)=> {
  12. const urls = typeof src === 'string' ? [src] : src
  13. const filePath = async src => src.match(/^http/) ? src : (await uni.compressImage({ src, quality: 100 }))[1].tempFilePath
  14. for (let i = 0; i < urls.length; i++) {
  15. urls[i] = await filePath(urls[i])
  16. }
  17. uni.previewImage({ urls })
  18. },
  19. util.showModel=(content,title='提示')=>{
  20. return new Promise((resolve,reject)=>{
  21. uni.showModal({
  22. title: title,
  23. content: content,
  24. success: (res)=>{
  25. resolve(res)
  26. }
  27. });
  28. })
  29. }
  30. //是否为手机号码
  31. util.isPhone = phone => {
  32. let pat = /^(13[0-9]|14[579]|15[0-3,5-9]|16[6]|17[0135678]|18[0-9]|19[89])\d{8}$/
  33. return pat.test(phone)
  34. }
  35. //去除两边空格
  36. util.trim = value => {
  37. if (value) {
  38. return value.replace(/^\s+|\s+$/gm, '')
  39. }
  40. return ''
  41. }
  42. //根据QueryString参数名称获取值
  43. util.getQueryStringByName = (url, name) => {
  44. var result = url.match(new RegExp('[?&]' + name + '=([^&]+)', 'i'))
  45. if (result == null || result.length < 1) {
  46. return ''
  47. }
  48. return result[1]
  49. }
  50. //四舍五入保留2位小数(不够位数,则用0替补)
  51. util.keepTwoDecimalFull = num => {
  52. var result = parseFloat(num)
  53. if (isNaN(result)) {
  54. return false
  55. }
  56. result = Math.round(num * 100) / 100
  57. var s_x = result.toString()
  58. var pos_decimal = s_x.indexOf('.')
  59. if (pos_decimal < 0) {
  60. pos_decimal = s_x.length
  61. s_x += '.'
  62. }
  63. while (s_x.length <= pos_decimal + 2) {
  64. s_x += '0'
  65. }
  66. return s_x
  67. }
  68. /**
  69. * 数组去重
  70. * @param {Array} arr 源数组
  71. *
  72. * @return {Array} newArr 去重后的数组
  73. */
  74. util.uniqueArray = (arr)=>{
  75. let newArr = []
  76. arr.forEach(item => {
  77. return newArr.includes(item) ? '' : newArr.push(item)
  78. })
  79. return newArr
  80. }
  81. util.checkMobile = phoneStr => {
  82. if (phoneStr.length < 11) {
  83. return false
  84. } else if (!/^1[3|4|5|6|7|8][0-9]\d{4,8}$/.test(phoneStr)) {
  85. return false
  86. } else {
  87. return true
  88. }
  89. }
  90. /**
  91. * 序列化对象
  92. * @param {Object} data 标准JS对象 { key:value,... }
  93. */
  94. util.serialize = (data, isEncode = false) => {
  95. if (!data) return ''
  96. var pairs = []
  97. for (var name in data) {
  98. if (!data.hasOwnProperty(name)) continue
  99. if (typeof data[name] === 'function') continue
  100. var value =
  101. data[name] != null && typeof data[name] != 'undefined'
  102. ? data[name].toString()
  103. : ''
  104. if (isEncode) {
  105. name = encodeURIComponent(name)
  106. value = encodeURIComponent(value)
  107. }
  108. pairs.push(name + '=' + value)
  109. }
  110. return pairs.join('&')
  111. }
  112. //获取某一个页面上下文 context
  113. util.getPageCtx = (idx = 0) => {
  114. let pages = getCurrentPages()
  115. if (pages.length > 0) {
  116. return pages[pages.length - 1 - idx] || {}
  117. }
  118. return {}
  119. }
  120. //获取当前页面路由
  121. util.getCurrentRoute = () => {
  122. let page = util.getPageCtx()
  123. if (page.route) {
  124. return page.route
  125. }
  126. return ''
  127. }
  128. /* ======================== 时间日期 begin ========================== */
  129. //日期转字符串
  130. util.dateToString = (date)=>{
  131. var year = date.getFullYear();
  132. var month =(date.getMonth() + 1).toString();
  133. var day = (date.getDate()).toString();
  134. if (month.length == 1) {
  135. month = "0" + month;
  136. }
  137. if (day.length == 1) {
  138. day = "0" + day;
  139. }
  140. var dateTime = year + "-" + month + "-" + day;
  141. return dateTime;
  142. }
  143. //字符串转日期
  144. util.stringToDate = (dateStr,separator)=>{
  145. if(!separator){
  146. separator="-";
  147. }
  148. var dateArr = dateStr.split(separator);
  149. var year = parseInt(dateArr[0]);
  150. var month;
  151. if(dateArr[1].indexOf("0") == 0){
  152. month = parseInt(dateArr[1].substring(1));
  153. }else{
  154. month = parseInt(dateArr[1]);
  155. }
  156. var day = parseInt(dateArr[2]);
  157. var date = new Date(year,month -1,day);
  158. return date;
  159. }
  160. /**
  161. * 天数加减
  162. * date传入你需要的日期,格式"xxxx-xx-xx"。addDays传要加减的日期数,往前传正数,往后传负数
  163. */
  164. util.addDay=(date,addDays)=>{
  165. var Dates = new Date(date);
  166. Dates.setDate(Dates.getDate() + addDays);
  167. var mon = Dates.getMonth() + 1,
  168. day = Dates.getDate();
  169. if(mon < 10){
  170. mon = "0" + mon;//月份小于10,在前面补充0
  171. }
  172. if(day < 10){
  173. day = "0" + day;//日小于10,在前面补充0
  174. }
  175. return Dates.getFullYear() + "-" + mon + "-" +day;
  176. }
  177. // 时间函数-tian=0(获取当前时间)-accuracy=1(获取年月日)
  178. util.getTime = (tian, accuracy) => {
  179. //获取当前时间戳
  180. var timestamp = Date.parse(new Date())
  181. timestamp = timestamp / 1000
  182. var tomorrow_timetamp = timestamp - tian * 24 * 60 * 60
  183. var date = new Date(tomorrow_timetamp * 1000)
  184. //年
  185. var Y = date.getFullYear()
  186. //月
  187. var M =
  188. date.getMonth() + 1 < 10 ? '0' + (date.getMonth() + 1) : date.getMonth() + 1
  189. //日
  190. var D = date.getDate() < 10 ? '0' + date.getDate() : date.getDate()
  191. //时
  192. var h = date.getHours() < 10 ? '0' + date.getHours() : date.getHours()
  193. //分
  194. var m = date.getMinutes() < 10 ? '0' + date.getMinutes() : date.getMinutes()
  195. //秒
  196. var s = date.getSeconds() < 10 ? '0' + date.getSeconds() : date.getSeconds()
  197. var Time = Y + '-' + M + '-' + D
  198. var Time2 = Y + '-' + M + '-' + D + ' ' + h + ':' + m + ':' + s
  199. if (accuracy == '1') {
  200. return Time
  201. } else {
  202. return Time2
  203. }
  204. }
  205. // 格式化日期 2019-01-01 TT(WW)
  206. util.dateFormat = (
  207. value = new Date(),
  208. format = 'yyyy-MM-dd',
  209. isInit = false
  210. ) => {
  211. if (value) {
  212. var date = typeof value == 'string' ? value.replace(/\-/g, '/') : value
  213. var d = new Date(date)
  214. var week = ''
  215. var label = ''
  216. if (isInit) {
  217. var cdt = new Date()
  218. var cur = new Date(
  219. cdt.getFullYear() + '/' + (cdt.getMonth() + 1) + '/' + cdt.getDate()
  220. )
  221. var diffTime = d.getTime() - cur.getTime()
  222. var oneDayTime = 24 * 60 * 60 * 1000
  223. var twoDayTime = 48 * 60 * 60 * 1000
  224. var threeDayTime = 72 * 60 * 60 * 1000
  225. let weeks = ['周日', '周一', '周二', '周三', '周四', '周五', '周六']
  226. if (diffTime > 0) {
  227. if (diffTime <= oneDayTime) {
  228. label = '今天'
  229. } else if (diffTime <= twoDayTime) {
  230. label = '明天'
  231. } else if (diffTime <= threeDayTime) {
  232. label = '后天'
  233. }
  234. }
  235. week = weeks[d.getDay()]
  236. }
  237. var o = {
  238. 'T+': label,
  239. 'W+': week,
  240. 'M+': d.getMonth() + 1, //month
  241. 'd+': d.getDate(), //day
  242. 'h+': d.getHours(), //hour
  243. 'm+': d.getMinutes(), //minute
  244. 's+': d.getSeconds(), //second
  245. 'q+': Math.floor((d.getMonth() + 3) / 3), //quarter
  246. S: d.getMilliseconds() //millisecond
  247. }
  248. if (/(y+)/.test(format)) {
  249. format = format.replace(
  250. RegExp.$1,
  251. (d.getFullYear() + '').substr(4 - RegExp.$1.length)
  252. )
  253. }
  254. for (var k in o) {
  255. if (k == 'T+' && !label) continue
  256. if (new RegExp('(' + k + ')').test(format)) {
  257. format = format.replace(
  258. RegExp.$1,
  259. RegExp.$1.length == 1
  260. ? o[k]
  261. : ('00' + o[k]).substr(('' + o[k]).length)
  262. )
  263. }
  264. }
  265. return format
  266. }
  267. return value
  268. }
  269. // 活动倒计时 需要在外面调用 如:setInterval("countDown()",1000);
  270. util.countDown = (day, hour, minute, second) => {
  271. var flag = false
  272. second -= 1
  273. if (second == 0) {
  274. minute = minute - 1
  275. second = 60
  276. if (minute < 0) {
  277. hour = hour - 1
  278. minute = 59
  279. if (hour < 0) {
  280. day -= 1
  281. hour = 23
  282. if (day < 0) {
  283. flag = true
  284. }
  285. }
  286. }
  287. }
  288. if (flag) {
  289. return '活动结束'
  290. } else {
  291. return day + '天' + hour + '小时' + minute + '分' + second + '秒'
  292. }
  293. }
  294. // 两个时间相差 天 小时 分钟 秒 date1、date2格式:'2019-06-29 14:36:10'或'2019/06/29 14:36:10'
  295. util.timeComparison = (date1, date2) => {
  296. // var date1 = '2019-06-29 14:36:10'; //开始时间
  297. // var date2 = new Date(); //结束时间
  298. var date3 = date2.getTime() - date1.getTime() //时间差的毫秒数
  299. //------------------------------
  300. //计算出相差天数
  301. var days = Math.floor(date3 / (24 * 3600 * 1000))
  302. //计算出小时数
  303. var leave1 = date3 % (24 * 3600 * 1000) //计算天数后剩余的毫秒数
  304. var hours = Math.floor(leave1 / (3600 * 1000))
  305. //计算相差分钟数
  306. var leave2 = leave1 % (3600 * 1000) //计算小时数后剩余的毫秒数
  307. var minutes = Math.floor(leave2 / (60 * 1000))
  308. //计算相差秒数
  309. var leave3 = leave2 % (60 * 1000) //计算分钟数后剩余的毫秒数
  310. var seconds = (leave3 / 1000).toFixed(1)
  311. return (
  312. ' 相差 ' +
  313. days +
  314. '天 ' +
  315. hours +
  316. '小时 ' +
  317. minutes +
  318. ' 分钟' +
  319. seconds +
  320. ' 秒'
  321. )
  322. }
  323. util.timeComparisonActive = (date1, date2, isNeedMillSecond = true) => {
  324. // var date1 = '2019-06-29 14:36:10'; //开始时间
  325. // var date2 = new Date(); //结束时间
  326. var date3 = date2.getTime() - date1.getTime() //时间差的毫秒数
  327. if (parseInt(date3) <= 0) {
  328. date3 = 0
  329. }
  330. //------------------------------
  331. //计算出相差天数
  332. var days = Math.floor(date3 / (24 * 3600 * 1000))
  333. //计算出小时数
  334. var leave1 = date3 % (24 * 3600 * 1000) //计算天数后剩余的毫秒数
  335. var hours = Math.floor(leave1 / (3600 * 1000))
  336. //计算相差分钟数
  337. var leave2 = leave1 % (3600 * 1000) //计算小时数后剩余的毫秒数
  338. var minutes = Math.floor(leave2 / (60 * 1000))
  339. //计算相差秒数
  340. var leave3 = leave2 % (60 * 1000) //计算分钟数后剩余的毫秒数
  341. if (isNeedMillSecond) {
  342. var seconds = (leave3 / 1000).toFixed(1)
  343. } else {
  344. var seconds = Math.floor(leave3 / 1000)
  345. }
  346. var allSeconds =
  347. days * 24 * 60 * 60 + hours * 60 * 60 + minutes * 60 + seconds
  348. hours = days * 24 + hours < 10 ? '0' + (days * 24 + hours) : days * 24 + hours
  349. minutes = minutes < 10 ? '0' + minutes : minutes
  350. seconds = seconds < 10 ? '0' + seconds : seconds
  351. days = days < 10 ? '0' + days : days
  352. var isEnd = allSeconds > 0 ? false : true
  353. return { days, hours, minutes, seconds, isEnd }
  354. }
  355. /**
  356. * 生成日期对象
  357. * @param {String,Number} value 日期 字符串 或者 毫秒数字
  358. * @return {Date} [date = new Date()] 日期对象
  359. */
  360. util.createDate = (value)=>{
  361. let date = typeof (value) == 'string' ? value.replace(/\-/g, '/') : value
  362. return new Date(date)
  363. }
  364. /* ======================== 时间日期 end ========================== */
  365. export default util