timeFormat.js 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. // padStart 的 polyfill,因为某些机型或情况,还无法支持es7的padStart,比如电脑版的微信小程序
  2. // 所以这里做一个兼容polyfill的兼容处理
  3. if (!String.prototype.padStart) {
  4. // 为了方便表示这里 fillString 用了ES6 的默认参数,不影响理解
  5. String.prototype.padStart = function(maxLength, fillString = ' ') {
  6. if (Object.prototype.toString.call(fillString) !== "[object String]") throw new TypeError(
  7. 'fillString must be String')
  8. let str = this
  9. // 返回 String(str) 这里是为了使返回的值是字符串字面量,在控制台中更符合直觉
  10. if (str.length >= maxLength) return String(str)
  11. let fillLength = maxLength - str.length,
  12. times = Math.ceil(fillLength / fillString.length)
  13. while (times >>= 1) {
  14. fillString += fillString
  15. if (times === 1) {
  16. fillString += fillString
  17. }
  18. }
  19. return fillString.slice(0, fillLength) + str;
  20. }
  21. }
  22. function timeFormat(timestamp = null, fmt = 'yyyy-mm-dd') {
  23. // 其他更多是格式化有如下:
  24. // yyyy:mm:dd|yyyy:mm|yyyy年mm月dd日|yyyy年mm月dd日 hh时MM分等,可自定义组合
  25. timestamp = parseInt(timestamp);
  26. // 如果为null,则格式化当前时间
  27. if (!timestamp) timestamp = Number(new Date());
  28. // 判断用户输入的时间戳是秒还是毫秒,一般前端js获取的时间戳是毫秒(13位),后端传过来的为秒(10位)
  29. if (timestamp.toString().length == 10) timestamp *= 1000;
  30. let date = new Date(timestamp);
  31. let ret;
  32. let opt = {
  33. "y+": date.getFullYear().toString(), // 年
  34. "m+": (date.getMonth() + 1).toString(), // 月
  35. "d+": date.getDate().toString(), // 日
  36. "h+": date.getHours().toString(), // 时
  37. "M+": date.getMinutes().toString(), // 分
  38. "s+": date.getSeconds().toString() // 秒
  39. // 有其他格式化字符需求可以继续添加,必须转化成字符串
  40. };
  41. for (let k in opt) {
  42. ret = new RegExp("(" + k + ")").exec(fmt);
  43. if (ret) {
  44. fmt = fmt.replace(ret[1], (ret[1].length == 1) ? (opt[k]) : (opt[k].padStart(ret[1].length, "0")))
  45. };
  46. };
  47. return fmt;
  48. }
  49. export default timeFormat