如何使用JavaScript中的格式规范将字符串转换为日期时间?


207

如何通过指定格式字符串将字符串转换为javascript中的日期时间对象?

我正在寻找类似的东西:

var dateTime = convertToDateTime("23.11.2009 12:34:56", "dd.MM.yyyy HH:mm:ss");

2
BTW点和连字符可能会因为日期分隔符而失败,斜杠可以,因此(在我的测试范围内),Javascript将接受“ 2011/08/22 10:30:00”,但尚未接受(尽管ISO 8601)“ 2011-09 -02 15:58:40“-据称-在Javascript 1.8.5及更高版本中受支持。
戴夫·埃弗里特

Date.parse函数解析“ mm / dd / yyyy”格式的日期字符串。在应用Parse之前,请将字符串转换为“ mm / dd / yyyy”格式。

为什么不以所需格式提供日期?我就像新的Date('2012 11 25 18:00:00'); 而且有效!
foxybagga 2012年

Answers:


88

我认为这可以为您提供帮助:http : //www.mattkruse.com/javascript/date/

有一个getDateFromFormat()功能,你可以调整有点解决您的问题。

更新:javascripttoolbox.com上有示例的更新版本


5
TypeError: Object Date has no method 'getDateFromFormat'
德里克·朕会功夫2012年

6
上面的链接上的文档提供了getDateFromFormat方法。可用资源在这里:mattkruse.com/javascript/date/source.html
拉斐尔·穆勒

1
+1,好的库。纯JavaScript ...太棒了。谢谢
Surendra Jnawali

7
两个链接都死了
Sytham

1
如果可以,请更新链接。这不再有用了。
塔勒莱

98

使用,如果你的字符串是兼容的。如果您的格式不兼容(我认为是),则必须自己解析该字符串(使用正则表达式应该很容易),并创建一个新的Date对象,该对象具有明确的年,月,日,时,分和秒的值。new Date(dateString)Date.parse()


1
Date.parse是最好的解决方案!它解析几乎所有内容!+1
ianaz

7
@ianaz:几乎所有在美国使用的格式,但缺少欧洲大部分地区使用的格式,“太大”了。但是新的Date是自定义功能的良好基础。
帕维尔五世

新的Date(dateString)对我来说很好用,Date.parse()转换为毫秒,因此返回数字而不是Date类型。
里根·奥乔拉

68

@Christoph使用正则表达式解决问题。这是我正在使用的:

var dateString = "2010-08-09 01:02:03";
var reggie = /(\d{4})-(\d{2})-(\d{2}) (\d{2}):(\d{2}):(\d{2})/;
var dateArray = reggie.exec(dateString); 
var dateObject = new Date(
    (+dateArray[1]),
    (+dateArray[2])-1, // Careful, month starts at 0!
    (+dateArray[3]),
    (+dateArray[4]),
    (+dateArray[5]),
    (+dateArray[6])
);

它绝不是智能的,只需配置正则表达式new Date(blah)即可满足您的需求。

编辑:使用解构,在ES6中也许更容易理解:

let dateString = "2010-08-09 01:02:03"
  , reggie = /(\d{4})-(\d{2})-(\d{2}) (\d{2}):(\d{2}):(\d{2})/
  , [, year, month, day, hours, minutes, seconds] = reggie.exec(dateString)
  , dateObject = new Date(year, month-1, day, hours, minutes, seconds);

但是,老实说,这些天我想要达到Moment之类的东西


19
@bažmegakapa不用哭,您也许可以编辑答案并添加'var's your own?
OrganicPanda 2012年

为什么使用/g标志,而仅设置lastIndex0之后?只是不要使用全局匹配。
Ry-

1
@minitech这/g是现有项目的草率复制/粘贴。lastindex是由编辑添加的(\g我想与之抗衡?)。我现在将其删除。感谢您指出这一点。
OrganicPanda 2012年

1
非常好的anwer ..对我真的有用
Jethik 2013年

14

JavaScript中不存在复杂的日期/时间格式化例程。

您将必须使用外部库来格式化日期输出,Flagrant Badassery的“ JavaScript Date Format”看起来非常有前途。

对于输入转换,已经提出了一些建议。:)


3
“必须”是相对的。当然,您可以构建自己的实现。:)
Tomalak

13

查看Moment.js。它是一个现代而强大的库,可弥补JavaScript的糟糕的Date函数(或缺少它们)。


3
我没有投票,但是确切地知道Moment.js中的哪个函数会给出期望的行为可能会很高兴(对于已经使用Moment.js但不知道要使用的特定函数的懒惰人来说) 。
马特

本地化看起来很有希望,可以选择任何中欧语言环境的点格式。但是,我没有对其进行测试,并且完整的日期时间格式不在我所看到的示例中。
Pavel V.

我没有拒绝投票,但我只是想告诉我这很慢。对于台式机来说还可以,但对于移动设备而言可能会太慢(取决于您的需求)。
gabn88 '16

11

只是为了获得更新的答案,在http://www.datejs.com/上有一个不错的js库

Datejs是一个开放源代码的JavaScript Date库,用于解析,格式化和处理。


回滚该编辑,尽管非常有用,但应将其添加为注释或单独的答案。
亚历克西斯·艾伯里

无论如何,评论已经太久了,添加重复的答案是错误的。这个问题有155,000多次浏览-让我们为这些人提供尽可能多的信息!(顺便说一下-编辑现有答案在Stack Overflow中很常见-如果我只复制您的答案,您可能会感到更糟...)
Kobi 2012年

1
而且无论如何,如果您不喜欢我的编辑很好,但是请扩大您的答案-“仅在此处提供更新的答案”是一种填充,并且缺少一些细节。顺便说一下,这个问题目前正在引起注意,这就是您突然获得5票的原因。
Kobi 2012年

7
var temp1 = "";
var temp2 = "";

var str1 = fd; 
var str2 = td;

var dt1  = str1.substring(0,2);
var dt2  = str2.substring(0,2);

var mon1 = str1.substring(3,5);
var mon2 = str2.substring(3,5);

var yr1  = str1.substring(6,10);  
var yr2  = str2.substring(6,10); 

temp1 = mon1 + "/" + dt1 + "/" + yr1;
temp2 = mon2 + "/" + dt2 + "/" + yr2;

var cfd = Date.parse(temp1);
var ctd = Date.parse(temp2);

var date1 = new Date(cfd); 
var date2 = new Date(ctd);

if(date1 > date2) { 
    alert("FROM DATE SHOULD BE MORE THAN TO DATE");
}

5

外部库对于解析一个或两个日期是一个过大的杀伤力,因此我使用OliChristoph的解决方案实现了自己的功能。在中欧,我们很少使用aything,而是使用OP的格式,因此对于此处使用的简单应用程序来说,这应该足够了。

function ParseDate(dateString) {
    //dd.mm.yyyy, or dd.mm.yy
    var dateArr = dateString.split(".");
    if (dateArr.length == 1) {
        return null;    //wrong format
    }
    //parse time after the year - separated by space
    var spacePos = dateArr[2].indexOf(" ");
    if(spacePos > 1) {
        var timeString = dateArr[2].substr(spacePos + 1);
        var timeArr = timeString.split(":");
        dateArr[2] = dateArr[2].substr(0, spacePos);
        if (timeArr.length == 2) {
            //minutes only
            return new Date(parseInt(dateArr[2]), parseInt(dateArr[1]-1), parseInt(dateArr[0]), parseInt(timeArr[0]), parseInt(timeArr[1]));
        } else {
            //including seconds
            return new Date(parseInt(dateArr[2]), parseInt(dateArr[1]-1), parseInt(dateArr[0]), parseInt(timeArr[0]), parseInt(timeArr[1]), parseInt(timeArr[2]))
        }
    } else {
        //gotcha at months - January is at 0, not 1 as one would expect
        return new Date(parseInt(dateArr[2]), parseInt(dateArr[1] - 1), parseInt(dateArr[0]));
    }
}

4

Date.parse() 是相当聪明的,但我不能保证格式会正确解析。

如果不是这样,则必须找到一些东西来桥接两者。您的示例非常简单(纯粹是数字),因此将REGEX(甚至string.split()-可能更快)与一些示例搭配使用,parseInt()可以使您快速约会。


4
time = "2017-01-18T17:02:09.000+05:30"

t = new Date(time)

hr = ("0" + t.getHours()).slice(-2);
min = ("0" + t.getMinutes()).slice(-2);
sec = ("0" + t.getSeconds()).slice(-2);

t.getFullYear()+"-"+t.getMonth()+1+"-"+t.getDate()+" "+hr+":"+min+":"+sec

调用函数getmonth()之后加1似乎是错误的
Arjunsingh

t.getMonth()+ 1是正确的,因为Date.getMonth()返回基于0的值。
Jussi Palo

3

只是给我5美分。

我的日期格式为dd.mm.yyyy(英国格式),以上示例均不适用于我。所有解析器都将mm视为天,将dd视为月。

我找到了这个库:http : //joey.mazzarelli.com/2008/11/25/easy-date-parsing-with-javascript/ 并且它起作用了,因为您可以说出如下字段的顺序:

>>console.log(new Date(Date.fromString('09.05.2012', {order: 'DMY'})));
Wed May 09 2012 00:00:00 GMT+0300 (EEST)

希望对您有所帮助。


链接现在死了!

嗯...一个快速的archive.org显示:项目网址是bitbucket.org/mazzarelli/js-date/downloads
安东·瓦尔克

1

Moment.js将处理此问题:

var momentDate = moment('23.11.2009 12:34:56', 'DD.MM.YYYY HH:mm:ss');
var date = momentDate.;

1
尽管moment.js很棒,但是有很多用例,您只需要使用本机Javascript。我当前的用例是CouchDB中的Map函数
Zach Smith

1

您可以为此使用moment.js库。我仅用于获取特定时间的输出,但是您可以选择想要选择的格式。

参考:

1.时刻库: https //momentjs.com/

2.特定于时间和日期的功能: https : //timestamp.online/article/how-to-convert-timestamp-to-datetime-in-javascript

convertDate(date) {
        var momentDate = moment(date).format('hh : mm A');
        return momentDate;
}

您可以像下面这样调用此方法:

this.convertDate('2020-05-01T10:31:18.837Z');

希望对您有所帮助。享受编码。


0

为了完全满足Date.parse的要求,将字符串转换为RFC822中指定的dd-mm-YYYY格式,如果您使用yyyy-mm-dd解析可能会出错。


仅供参考,摘自RFC 822(第25页。部分清理以符合评论的文字长度):1982年8月13日-25-RFC#822 5.日期和时间规范5.1。语法date-time = [day“,”]日期时间;dd mm yy hh:mm:ss zzz day =“ Mon” /“ Tue” /“ Wed” /“ Thu” /“ Fri” /“ Sat” /“ Sun” date = 1 * 2DIGIT month 2DIGIT; 年月年,例如82年6月20日=“ 1月” /“ 2月” /“ 3月” /“ 4月” /“ 5月” /“ 6月” /“ 7月” /“ 8月” /“ 9月” /“ 10月” /“ 11月” /“ 12月”
Valentin Rusk

0
//Here pdate is the string date time
var date1=GetDate(pdate);
    function GetDate(a){
        var dateString = a.substr(6);
        var currentTime = new Date(parseInt(dateString ));
        var month =("0"+ (currentTime.getMonth() + 1)).slice(-2);
        var day =("0"+ currentTime.getDate()).slice(-2);
        var year = currentTime.getFullYear();
        var date = day + "/" + month + "/" + year;
        return date;
    }

查询者要求指定格式字符串
阿玛利

@Armali以字符串格式输入参数,例如“ / Date(1552415400000)/”
Abhishek Kanrar,
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.