formatTime.ts 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. import dayjs from 'dayjs'
  2. /**
  3. * 时间日期转换
  4. * @param date 当前时间,new Date() 格式
  5. * @param format 需要转换的时间格式字符串
  6. * @description format 字符串随意,如 `YYYY-mm、YYYY-mm-dd`
  7. * @description format 季度:"YYYY-mm-dd HH:MM:SS QQQQ"
  8. * @description format 星期:"YYYY-mm-dd HH:MM:SS WWW"
  9. * @description format 几周:"YYYY-mm-dd HH:MM:SS ZZZ"
  10. * @description format 季度 + 星期 + 几周:"YYYY-mm-dd HH:MM:SS WWW QQQQ ZZZ"
  11. * @returns 返回拼接后的时间字符串
  12. */
  13. export function formatDate(date: Date, format: string): string {
  14. return dayjs(date).format(format)
  15. }
  16. /**
  17. * 获取当前日期是第几周
  18. * @param dateTime 当前传入的日期值
  19. * @returns 返回第几周数字值
  20. */
  21. export function getWeek(dateTime: Date): number {
  22. const temptTime = new Date(dateTime.getTime())
  23. // 周几
  24. const weekday = temptTime.getDay() || 7
  25. // 周1+5天=周六
  26. temptTime.setDate(temptTime.getDate() - weekday + 1 + 5)
  27. let firstDay = new Date(temptTime.getFullYear(), 0, 1)
  28. const dayOfWeek = firstDay.getDay()
  29. let spendDay = 1
  30. if (dayOfWeek != 0) spendDay = 7 - dayOfWeek + 1
  31. firstDay = new Date(temptTime.getFullYear(), 0, 1 + spendDay)
  32. const d = Math.ceil((temptTime.valueOf() - firstDay.valueOf()) / 86400000)
  33. const result = Math.ceil(d / 7)
  34. return result
  35. }
  36. /**
  37. * 将时间转换为 `几秒前`、`几分钟前`、`几小时前`、`几天前`
  38. * @param param 当前时间,new Date() 格式或者字符串时间格式
  39. * @param format 需要转换的时间格式字符串
  40. * @description param 10秒: 10 * 1000
  41. * @description param 1分: 60 * 1000
  42. * @description param 1小时: 60 * 60 * 1000
  43. * @description param 24小时:60 * 60 * 24 * 1000
  44. * @description param 3天: 60 * 60* 24 * 1000 * 3
  45. * @returns 返回拼接后的时间字符串
  46. */
  47. export function formatPast(param: string | Date, format = 'YYYY-mm-dd HH:MM:SS'): string {
  48. // 传入格式处理、存储转换值
  49. let t: any, s: number
  50. // 获取js 时间戳
  51. let time: number = new Date().getTime()
  52. // 是否是对象
  53. typeof param === 'string' || 'object' ? (t = new Date(param).getTime()) : (t = param)
  54. // 当前时间戳 - 传入时间戳
  55. time = Number.parseInt(`${time - t}`)
  56. if (time < 10000) {
  57. // 10秒内
  58. return '刚刚'
  59. } else if (time < 60000 && time >= 10000) {
  60. // 超过10秒少于1分钟内
  61. s = Math.floor(time / 1000)
  62. return `${s}秒前`
  63. } else if (time < 3600000 && time >= 60000) {
  64. // 超过1分钟少于1小时
  65. s = Math.floor(time / 60000)
  66. return `${s}分钟前`
  67. } else if (time < 86400000 && time >= 3600000) {
  68. // 超过1小时少于24小时
  69. s = Math.floor(time / 3600000)
  70. return `${s}小时前`
  71. } else if (time < 259200000 && time >= 86400000) {
  72. // 超过1天少于3天内
  73. s = Math.floor(time / 86400000)
  74. return `${s}天前`
  75. } else {
  76. // 超过3天
  77. const date = typeof param === 'string' || 'object' ? new Date(param) : param
  78. return formatDate(date, format)
  79. }
  80. }
  81. /**
  82. * 时间问候语
  83. * @param param 当前时间,new Date() 格式
  84. * @description param 调用 `formatAxis(new Date())` 输出 `上午好`
  85. * @returns 返回拼接后的时间字符串
  86. */
  87. export function formatAxis(param: Date): string {
  88. const hour: number = new Date(param).getHours()
  89. if (hour < 6) return '凌晨好'
  90. else if (hour < 9) return '早上好'
  91. else if (hour < 12) return '上午好'
  92. else if (hour < 14) return '中午好'
  93. else if (hour < 17) return '下午好'
  94. else if (hour < 19) return '傍晚好'
  95. else if (hour < 22) return '晚上好'
  96. else return '夜里好'
  97. }
  98. /**
  99. * 将毫秒,转换成时间字符串。例如说,xx 分钟
  100. *
  101. * @param ms 毫秒
  102. * @returns {string} 字符串
  103. */
  104. export function formatPast2(ms) {
  105. const day = Math.floor(ms / (24 * 60 * 60 * 1000))
  106. const hour = Math.floor(ms / (60 * 60 * 1000) - day * 24)
  107. const minute = Math.floor(ms / (60 * 1000) - day * 24 * 60 - hour * 60)
  108. const second = Math.floor(ms / 1000 - day * 24 * 60 * 60 - hour * 60 * 60 - minute * 60)
  109. if (day > 0) {
  110. return day + '天' + hour + '小时' + minute + '分钟'
  111. }
  112. if (hour > 0) {
  113. return hour + '小时' + minute + '分钟'
  114. }
  115. if (minute > 0) {
  116. return minute + '分钟'
  117. }
  118. if (second > 0) {
  119. return second + '秒'
  120. } else {
  121. return 0 + '秒'
  122. }
  123. }
  124. /**
  125. * element plus 的时间 Formatter 实现,使用 YYYY-MM-DD HH:mm:ss 格式
  126. *
  127. * @param row 行数据
  128. * @param column 字段
  129. * @param cellValue 字段值
  130. */
  131. // @ts-ignore
  132. export const dateFormatter = (row, column, cellValue) => {
  133. if (!cellValue) {
  134. return
  135. }
  136. return dayjs(cellValue).format('YYYY-MM-DD HH:mm:ss')
  137. }