随笔 - 42,  文章 - 0,  评论 - 12,  阅读 - 51248

小伙伴们平时开发过程中,对获取到的本地时间有没有进行一些特殊的处理啊。比如页面需要展示这样的时间:2021.07.22、2021/07/22、2021-07-22等 。

下面我们封装一个方法,可以获取自定义格式的日期格式,可自定义精确到年月日时分秒哦~ 上代码:

复制代码
 1 /**
 2  * 
 3  * @param {number|string} timestamp,默认是当前时间戳
 4  * @param {string} format 'year' || 'month' || 'day' || 'hour' || 'minute' || 'second' 默认到秒 second
 5  *  @param {string} divider 年月日之间的间隔符,默认是 -
 6  * @returns 
 7  */
 8 export function getDate(timestamp, format, divider='-') {
 9   if (timestamp && isNaN(timestamp)) return false;
10   if ((timestamp + '').includes('.')) return false;
11   var _timestamp = timestamp || new Date().getTime();
12   function add0(m) { return m < 10 ? '0' + m : m };
13   var time = new Date(Number(_timestamp));
14   var y = time.getFullYear();
15   var m = time.getMonth() + 1;
16   var d = time.getDate();
17   var h = time.getHours();
18   var mm = time.getMinutes();
19   var s = time.getSeconds();
20   switch (format) {
21     case 'year':
22       return y;
23     case 'month':
24       return y + divider + add0(m);
25     case 'day':
26       return y + divider + add0(m) + divider + add0(d);
27     case 'hour':
28       return y + divider + add0(m) + divider + add0(d) + ' ' + add0(h);
29     case 'minute':
30       return y + divider + add0(m) + divider + add0(d) + ' ' + add0(h) + ':' + add0(mm);
31     case 'second':
32       return y + divider + add0(m) + divider + add0(d) + ' ' + add0(h) + ':' + add0(mm) + ':' + add0(s);
33     default:
34       return y + divider + add0(m) + divider + add0(d) + ' ' + add0(h) + ':' + add0(mm) + ':' + add0(s);
35   }
36 }
复制代码

 效果图:

  更多项目中常见的方法封装,传送门https://github.com/wangruibin666/wang-utils 

脚踏实地行,海阔天空飞~

posted on   coder__wang  阅读(687)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 因为Apifox不支持离线,我果断选择了Apipost!
· 通过 API 将Deepseek响应流式内容输出到前端
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示