不要再问我前端如何让字符串转成Date了

简介: 不要再问我前端如何让字符串转成Date了

生活就像一盒巧克力,你永远不知道你会得到什么。——《阿甘正传》

那天有朋友问我yyyy-MM-dd'T'HH:mm:ss.SSSZ怎么转成yyyy-MM-dd HH:mm:ss,我就给他了我这篇博客

结果他说看完还是不会。。。

那我今天再讲一次吧

首先,我们拿到一个字符串2018-05-23T16:05:52+08:00

很多程序员看到了就不知道如何下手了

我们理清思路:

1.将字符串转换成js中的Date对象

2.调用Date对象中的函数转换为我们想要的格式

我们首先调用Date的构造方法

var a = "2018-05-23T16:05:52+08:00"
console.log(a)
var date = new Date(a);
console.log(date)

可以看到我们的date确实转成功了

当然,除了这种格式的日期字符串

还可以支持很多格式

以及我们的时间戳

如果这些格式都不能满足你

还有一招:按照

1
newDate(年,月,日,时,分,秒,毫秒)

的格式去转换,注意月这里需要减一

同上,也支持省略写法

有朋友说,诶我这个是个字符串,我怎么取出里面的年月日呢?

这个可以根据具体情况具体分析,例如我是中文的这种2018年5月23日16时05分52秒

我们通过Stringsplit函数,使用正则去匹配分隔成数组,然后再传入进去

var a = '2018年5月23日16时05分52秒'.split(/[^0-9]/)
console.log(a)
new Date(a[0], a[1] - 1, a[2], a[3], a[4], a[5])

好!!!终于我们完成了第一步

第二步就是转成字符串。。。

var dateUtils = {
        // 将Date对象格式化为"yyyy-mm-dd HH:MM:ss"格式
        format: function (date) {
            var _format = function (number) {
                return (number < 10 ? ('0' + number) : number);
            };
            return date.getFullYear() + '-' + _format(date.getMonth() + 1) + '-' + _format(date.getDate()) +
                ' ' +
                _format(date.getHours()) + ':' + _format(date.getMinutes()) + ':' + _format(date.getSeconds());
        }
    }
dateUtils.format(new Date())

这里调用了很多Date里的函数,在之前这篇博客是列出了几乎全部的api。。。

如果还有人不会日期和字符串任意转换。。。祥林嫂,你放着罢!

相关文章
|
存储 算法 前端开发
前端算法-删除字符串中的所有相邻重复项
前端算法-删除字符串中的所有相邻重复项
|
10月前
|
前端开发
前端使用正则表达式检查是否为十六进制字符串
前端使用正则表达式检查是否为十六进制字符串
247 6
|
前端开发 JavaScript 索引
前端切图仔,常用的21个字符串方法(上)
前端切图仔,常用的21个字符串方法(上)
199 1
|
前端开发 JavaScript 索引
前端切图仔,常用的21个字符串方法(下)
前端切图仔,常用的21个字符串方法(下)
193 0
|
前端开发 JavaScript Java
【前端学java】详解java中的字符串操作(11)
【8月更文挑战第10天】详解java中的字符串操作
127 3
【前端学java】详解java中的字符串操作(11)
|
前端开发 JavaScript
前端基础(十五)_时间对象、字符串对象
本文介绍了JavaScript中时间对象的操作方法,包括获取和设置年、月、日、小时、分钟、秒等,以及如何格式化时间显示,同时提及了字符串对象的常用方法。
312 0
前端基础(十五)_时间对象、字符串对象
|
前端开发
前端——关于字符串的操作整理
前端——关于字符串的操作整理
|
前端开发
前端项目实战玖拾伍react-admin+material ui-踩坑-List的用法之disableSyncWithLocation查询字符串同步
前端项目实战玖拾伍react-admin+material ui-踩坑-List的用法之disableSyncWithLocation查询字符串同步
216 0
|
前端开发 JavaScript
前端 js 经典:Date
前端 js 经典:Date
180 2
|
前端开发 JavaScript 流计算
前端 js 经典:字符串超全方法总结
前端 js 经典:字符串超全方法总结
243 0

热门文章

最新文章

  • 1
    前端如何存储数据:Cookie、LocalStorage 与 SessionStorage 全面解析
    877
  • 2
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(九):强势分析Animation动画各类参数;从播放时间、播放方式、播放次数、播放方向、播放状态等多个方面,完全了解CSS3 Animation
    402
  • 3
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(八):学习transition过渡属性;本文学习property模拟、duration过渡时间指定、delay时间延迟 等多个参数
    305
  • 4
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(七):学习ransform属性;本文学习 rotate旋转、scale缩放、skew扭曲、tanslate移动、matrix矩阵 多个参数
    273
  • 5
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(六):全方面分析css的Flex布局,从纵、横两个坐标开始进行居中、两端等元素分布模式;刨析元素间隔、排序模式等
    399
  • 6
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(五):背景属性;float浮动和position定位;详细分析相对、绝对、固定三种定位方式;使用浮动并清除浮动副作用
    582
  • 7
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(四):元素盒子模型;详细分析边框属性、盒子外边距
    613
  • 8
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(三):元素继承关系、层叠样式规则、字体属性、文本属性;针对字体和文本作样式修改
    187
  • 9
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(二):CSS伪类:UI伪类、结构化伪类;通过伪类获得子元素的第n个元素;创建一个伪元素展示在页面中;获得最后一个元素;处理聚焦元素的样式
    530
  • 10
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(一):CSS发展史;CSS样式表的引入;CSS选择器使用,附带案例介绍
    344