将Unix时间戳转换为JavaScript中的时间


1157

我将时间作为Unix时间戳存储在MySQL数据库中,并将其发送到一些JavaScript代码。我怎么会得到时间呢?

例如,以HH / MM / SS格式。


5
只需乘以1000,因为JS时间戳以毫秒为单位,PHP传递以秒为单位。
ankr

这是一个非常有用的链接,具有不同的日期格式:timestamp.online/article / ...与1000相乘相结合就可以完成工作!
Kevin Lemaire

Answers:


1728

let unix_timestamp = 1549312452
// Create a new JavaScript Date object based on the timestamp
// multiplied by 1000 so that the argument is in milliseconds, not seconds.
var date = new Date(unix_timestamp * 1000);
// Hours part from the timestamp
var hours = date.getHours();
// Minutes part from the timestamp
var minutes = "0" + date.getMinutes();
// Seconds part from the timestamp
var seconds = "0" + date.getSeconds();

// Will display time in 10:30:23 format
var formattedTime = hours + ':' + minutes.substr(-2) + ':' + seconds.substr(-2);

console.log(formattedTime);

有关Date对象的更多信息,请参考MDNECMAScript 5规范


114
@nickf乘法是微不足道的现代的CPU -字符串连接将需要大量更多的工作!
Alnitak

4
串联应该包括读取内存和写入内存。某人如何设计一些需要简单处理的内容(例如附加),使其比万用表更复杂...问一个孩子要串联,他们可以..多重乘积会更困难...加上内存可以线性地线性工作...有人可以提供对@nickf注释的引用吗?

29
实际上,它将以“ 10:2:2”格式显示时间,因为它不会在值低于10之前添加额外的
0。– Fireblaze 2012年

16
@ user656925-乘法涉及数字,串联涉及字符串。计算机处理数字的效率远高于字符串。字符串连接完成后,后台将进行大量内存管理。(但是,无论如何,如果您已经在进行字符串连接,那么在其中一个字符串中包含几个额外的字符实际上实际上比在一个处理器上将两个数字相乘的成本更低。)
Brilliand

6
@Stallman数计算是计算机执行的最基本的操作,并且在内存和运行时方面都非常高效。上面的Brilliand的评论是有意义的,尽管恕我直言,他的评论的最后部分完全是伪造的。
Alnitak

297

function timeConverter(UNIX_timestamp){
  var a = new Date(UNIX_timestamp * 1000);
  var months = ['Jan','Feb','Mar','Apr','May','Jun','Jul','Aug','Sep','Oct','Nov','Dec'];
  var year = a.getFullYear();
  var month = months[a.getMonth()];
  var date = a.getDate();
  var hour = a.getHours();
  var min = a.getMinutes();
  var sec = a.getSeconds();
  var time = date + ' ' + month + ' ' + year + ' ' + hour + ':' + min + ':' + sec ;
  return time;
}
console.log(timeConverter(0));


对于HH / MM / SS,只需使用最后三个变量,这将是您当地的时间,但是如果要获取UTC时间,请使用getUTC方法。这是代码。
shomrat

36
我使用了此解决方案,但对其进行了调整,以使分钟和秒显示为:03或:09而不是:3或:9,如下所示:var min = a.getMinutes() < 10 ? '0' + a.getMinutes() : a.getMinutes(); var sec = a.getSeconds() < 10 ? '0' + a.getSeconds() : a.getSeconds();
user1985189

3
错误:getMonth()返回0到11之间的月份数,因此a.getMonth() - 1是错误的。
jcampbell1 2014年

195

JavaScript以毫秒为单位工作,因此您首先必须将UNIX时间戳从秒转换为毫秒。

var date = new Date(UNIX_Timestamp * 1000);
// Manipulate JavaScript Date object here...


71

采用:

var s = new Date(1504095567183).toLocaleDateString("en-US")
console.log(s)
// expected output "8/30/2017"  

时间:

var s = new Date(1504095567183).toLocaleTimeString("en-US")
console.log(s)
// expected output "3:19:27 PM"

参见Date.prototype.toLocaleDateString()


这是用于获取日期(M / D / YYYY)而不是请求的时间(HH / MM / SS)的命令。
沃尔夫冈'18

2
请注意,数字“ 1504095567183”是unix_timestamp * 1000
camillo777

1
此外,toLocaleString还包括日期和时间。
肖恩

56

这是将秒格式设置为的最短的一线解决方案hh:mm:ss

/**
 * Convert seconds to time string (hh:mm:ss).
 *
 * @param Number s
 *
 * @return String
 */
function time(s) {
    return new Date(s * 1e3).toISOString().slice(-13, -5);
}

console.log( time(12345) );  // "03:25:45"

方法Date.prototype.toISOString()以简化的扩展ISO 8601格式返回时间,该时间始终为 24或27个字符(即分别为YYYY-MM-DDTHH:mm:ss.sssZ±YYYYYY-MM-DDTHH:mm:ss.sssZ)。时区始终为零UTC偏移。

注意:此解决方案不需要任何第三方库,并且在所有现代浏览器和JavaScript引擎中均受支持。


我在Chrome的控制台中粘贴了您的功能:/即使在您的小提琴中,它也为我显示01:02:00!在Firefox上尝试过,结果相同。很奇怪...我很确定这是因为我是GMT + 1!
史蒂夫·查麦拉德

我为您的答案提供了一个修改,它忽略了任何时区,因此它将始终显示正确的格式化值!
史蒂夫·查麦拉德

1
@SteveChamaillard谢谢你,史蒂夫。您说的没错,toTimeString与时区的配合不好。不幸的是,您的修改在我看到之前被拒绝了。但是,我建议toISOString改用它,因为toGMTString它已被弃用,并且可能在不同平台上返回不同的结果。
VisioN

使用ES6时甚至更短:let time = s => new Date(s * 1e3).toISOString()。slice(-13,-5)
SamGoody

28

我会考虑使用诸如momentjs.com之类的库这样,这使得这真的很简单:

基于Unix时间戳:

var timestamp = moment.unix(1293683278);
console.log( timestamp.format("HH/mm/ss") );

基于MySQL日期字符串:

var now = moment("2010-10-10 12:03:15");
console.log( now.format("HH/mm/ss") );

3
moment.js(或类似的库)的另一个优点是它们支持相对时间,例如“ 6小时前”之类的消息。
马丁

在您的console.log示例中,由于,我对格式感到困惑/,但这对我很有帮助。
NetOperator Wibby

我的时间戳是UTC格式。我需要为此做任何更改吗?我怎么可以上午/下午?
编解码器

moment.js对于这么小的事情来说是过大的,会影响您的性能。请改用本机方法,请参见。丹Alboteanu的答案
罗宾梅特拉尔

22

UNIX时间戳是数(根据00:00:00以来UTC 1970年1月1日,维基百科)。

Javascript中的Date对象的参数是自1970年1月1日00:00:00 UTC以来的毫秒数(根据W3Schools Javascript文档)。

例如,请参见下面的代码:

    function tm(unix_tm) {
        var dt = new Date(unix_tm*1000);
        document.writeln(dt.getHours() + '/' + dt.getMinutes() + '/' + dt.getSeconds() + ' -- ' + dt + '<br>');

    }

tm(60);
tm(86400);

给出:

1/1/0 -- Thu Jan 01 1970 01:01:00 GMT+0100 (Central European Standard Time)
1/0/0 -- Fri Jan 02 1970 01:00:00 GMT+0100 (Central European Standard Time)

19

将秒格式为hh:mm:ss:变体的最短的一线解决方案:

console.log(new Date(1549312452 * 1000).toISOString().slice(0, 19).replace('T', ' '));
// "2019-02-04 20:34:12"


1
当与PHP unix时间戳一起使用时,由于某种原因,我比实际时间+ 5h:/
keanu_reeves

2
@keanu_reeves-听起来您在美国东部时区,并且时间戳是UTC。尝试删除.slice(0,19),我认为您会看到结果的时区为Z(Zulu)。
bitfiddler

17

使用Moment.js,您可以像这样获得时间和日期:

var dateTimeString = moment(1439198499).format("DD-MM-YYYY HH:mm:ss");

您只能使用以下时间:

var timeString = moment(1439198499).format("HH:mm:ss");

您知道如何反向执行此操作吗,例如将DD-MM-YYYY HH:mm:ss格式转换为类似1439198499的格式?
Kemat Rochi

嗨,凯马特,您可以通过此语句moment('2009-07-15 00:00:00')。unix()
Peter T.

我的时间戳是UTC格式。我需要在这里为此做任何改变吗?我怎么可以上午/下午?
编解码器

您可以轻松地将时间戳转换为日期usign momentJS,您可以检出此coderszine.com/convert-timestamp-to-date-using-javascript
Laeeq,

15

前述解决方案的问题是,如果小时,分钟或秒只有一位数字(即0-9),则时间将是错误的,例如可能是2:3:9,而应该是02: 03:09。

根据此页面,使用Date的“ toLocaleTimeString”方法似乎是更好的解决方案。


5
对于大多数Web解决方案,这是最正确的答案,因为它使用客户端的语言环境,例如24h与12h am / pm格式。对于时间字符串,您将使用:date.toLocaleTimeString()
Bachi 2013年

1
toTimeString方法不会发生。在这里检查:stackoverflow.com/a/35890537/1249581
VisioN

14

另一种方式-从ISO 8601开始。

var timestamp = 1293683278;
var date = new Date(timestamp * 1000);
var iso = date.toISOString().match(/(\d{2}:\d{2}:\d{2})/)
alert(iso[1]);


我得到“对象...没有方法'toISOString'”
Aviram Netanel 2014年

我的时间戳是UTC格式。我需要在这里为此做任何改变吗?我怎么可以上午/下午?
编解码器

13

此刻,您必须使用unix时间戳:

var dateTimeString = moment.unix(1466760005).format("DD-MM-YYYY HH:mm:ss");

10

根据@shomrat的答案,下面是一个片段,该片段会自动编写这样的日期时间(有点类似于StackOverflow的答案日期:)answered Nov 6 '16 at 11:51

today, 11:23

要么

yersterday, 11:23

或(如果与今天不同但同一年)

6 Nov, 11:23

或(如果比今天多一年)

6 Nov 2016, 11:23

function timeConverter(t) {     
    var a = new Date(t * 1000);
    var today = new Date();
    var yesterday = new Date(Date.now() - 86400000);
    var months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'];
    var year = a.getFullYear();
    var month = months[a.getMonth()];
    var date = a.getDate();
    var hour = a.getHours();
    var min = a.getMinutes();
    if (a.setHours(0,0,0,0) == today.setHours(0,0,0,0))
        return 'today, ' + hour + ':' + min;
    else if (a.setHours(0,0,0,0) == yesterday.setHours(0,0,0,0))
        return 'yesterday, ' + hour + ':' + min;
    else if (year == today.getFullYear())
        return date + ' ' + month + ', ' + hour + ':' + min;
    else
        return date + ' ' + month + ' ' + year + ', ' + hour + ':' + min;
}

9

不需要40 KB库的现代解决方案:

Intl.DateTimeFormat是格式化日期/时间的非文化帝国主义方式。

// Setup once
var options = {
    //weekday: 'long',
    //month: 'short',
    //year: 'numeric',
    //day: 'numeric',
    hour: 'numeric',
    minute: 'numeric',
    second: 'numeric'
},
intlDate = new Intl.DateTimeFormat( undefined, options );

// Reusable formatter
var timeStamp = 1412743273;
console.log( intlDate.format( new Date( 1000 * timeStamp ) ) );

关于“非文化帝国主义方式”:你不是说“非文化非帝国主义方式”吗?
彼得·莫滕森

不幸的是,此方法与Safari不兼容。
Stephen S.

9

我的时间戳是从PHP后端获取的。我尝试了上述所有方法,但没有成功。然后,我遇到了一个有效的教程:

var d =val.timestamp;
var date=new Date(+d); //NB: use + before variable name

console.log(d);
console.log(date.toDateString());
console.log(date.getFullYear());
console.log(date.getMinutes());
console.log(date.getSeconds());
console.log(date.getHours());
console.log(date.toLocaleTimeString());

上面的方法将产生此结果

1541415288860
Mon Nov 05 2018 
2018 
54 
48 
13
1:54:48 PM

有很多方法可以与时间戳完美配合。不能全部列出


8
function getTIMESTAMP() {
  var date = new Date();
  var year = date.getFullYear();
  var month = ("0" + (date.getMonth() + 1)).substr(-2);
  var day = ("0" + date.getDate()).substr(-2);
  var hour = ("0" + date.getHours()).substr(-2);
  var minutes = ("0" + date.getMinutes()).substr(-2);
  var seconds = ("0" + date.getSeconds()).substr(-2);

  return year + "-" + month + "-" + day + " " + hour + ":" + minutes + ":" + seconds;
}

//2016-01-14 02:40:01

工作良好。谢谢
弗拉德

6

注意一些答案,以解决零问题。例如,时间戳1439329773将被错误地转换为12/08/2015 0:49

我建议使用以下方法来解决此问题:

var timestamp = 1439329773; // replace your timestamp
var date = new Date(timestamp * 1000);
var formattedDate = ('0' + date.getDate()).slice(-2) + '/' + ('0' + (date.getMonth() + 1)).slice(-2) + '/' + date.getFullYear() + ' ' + ('0' + date.getHours()).slice(-2) + ':' + ('0' + date.getMinutes()).slice(-2);
console.log(formattedDate);

现在结果为:

12/08/2015 00:49

5
// Format value as two digits 0 => 00, 1 => 01
function twoDigits(value) {
   if(value < 10) {
    return '0' + value;
   }
   return value;
}

var date = new Date(unix_timestamp*1000);
// display in format HH:MM:SS
var formattedTime = twoDigits(date.getHours()) 
      + ':' + twoDigits(date.getMinutes()) 
      + ':' + twoDigits(date.getSeconds());

我认为您不需要额外的独立函数来在需要时获取尾随零的数字-请参阅底部的答案。
trejder

2
@trejder,在您的示例中,您将逻辑重复,而使用额外的功能则将其放在一个位置。同样,您在这里总是两次触发日期函数(例如getHours()),这是一次调用。您永远无法知道要重新执行某些库函数有多沉重(但是我确实相信它对于日期而言是轻巧的)。
2014年

4
function timeConverter(UNIX_timestamp){
 var a = new Date(UNIX_timestamp*1000);
     var hour = a.getUTCHours();
     var min = a.getUTCMinutes();
     var sec = a.getUTCSeconds();
     var time = hour+':'+min+':'+sec ;
     return time;
 }

4

请参阅日期/时间转换器

您需要ParseInt,否则将无法正常工作:


if (!window.a)
    window.a = new Date();

var mEpoch = parseInt(UNIX_timestamp);

if (mEpoch < 10000000000)
    mEpoch *= 1000;

------
a.setTime(mEpoch);
var year = a.getFullYear();
...
return time;

4

您可以使用以下函数将时间戳转换为HH:MM:SSformat:

var convertTime = function(timestamp, separator) {
    var pad = function(input) {return input < 10 ? "0" + input : input;};
    var date = timestamp ? new Date(timestamp * 1000) : new Date();
    return [
        pad(date.getHours()),
        pad(date.getMinutes()),
        pad(date.getSeconds())
    ].join(typeof separator !== 'undefined' ?  separator : ':' );
}

在不传递分隔符的情况下,它:用作(默认)分隔符:

time = convertTime(1061351153); // --> OUTPUT = 05:45:53

如果要/用作分隔符,只需将其作为第二个参数传递:

time = convertTime(920535115, '/'); // --> OUTPUT = 09/11/55

演示版

var convertTime = function(timestamp, separator) {
    var pad = function(input) {return input < 10 ? "0" + input : input;};
    var date = timestamp ? new Date(timestamp * 1000) : new Date();
    return [
        pad(date.getHours()),
        pad(date.getMinutes()),
        pad(date.getSeconds())
    ].join(typeof separator !== 'undefined' ?  separator : ':' );
}

document.body.innerHTML = '<pre>' + JSON.stringify({
    920535115 : convertTime(920535115, '/'),
    1061351153 : convertTime(1061351153, ':'),
    1435651350 : convertTime(1435651350, '-'),
    1487938926 : convertTime(1487938926),
    1555135551 : convertTime(1555135551, '.')
}, null, '\t') +  '</pre>';

另请参见此Fiddle


3

 function getDateTimeFromTimestamp(unixTimeStamp) {
        var date = new Date(unixTimeStamp);
        return ('0' + date.getDate()).slice(-2) + '/' + ('0' + (date.getMonth() + 1)).slice(-2) + '/' + date.getFullYear() + ' ' + ('0' + date.getHours()).slice(-2) + ':' + ('0' + date.getMinutes()).slice(-2);
      }

    var myTime = getDateTimeFromTimestamp(1435986900000);
    console.log(myTime); // output 01/05/2000 11:00


这不是Unix时间戳:1435986900000 /这是Unix时间戳:1435986900
Orici

此解决方案对我有用,但是我怎么能用2月3月4月这样的月份代替数字?
abidinberkay

2

如果要将Unix持续时间转换为真实的小时,分​​钟和秒,则可以使用以下代码:

var hours = Math.floor(timestamp / 60 / 60);
var minutes = Math.floor((timestamp - hours * 60 * 60) / 60);
var seconds = Math.floor(timestamp - hours * 60 * 60 - minutes * 60 );
var duration = hours + ':' + minutes + ':' + seconds;

1
function getDateTime(unixTimeStamp) {

    var d = new Date(unixTimeStamp);
    var h = (d.getHours().toString().length == 1) ? ('0' + d.getHours()) : d.getHours();
    var m = (d.getMinutes().toString().length == 1) ? ('0' + d.getMinutes()) : d.getMinutes();
    var s = (d.getSeconds().toString().length == 1) ? ('0' + d.getSeconds()) : d.getSeconds();

    var time = h + '/' + m + '/' + s;

    return time;
}

var myTime = getDateTime(1435986900000);
console.log(myTime); // output 01/15/00

1

下面的代码还提供了三位数的毫秒,非常适合控制台日志前缀:

const timeStrGet = date => {
    const milliSecsStr = date.getMilliseconds().toString().padStart(3, '0') ;
    return `${date.toLocaleTimeString('it-US')}.${milliSecsStr}`;
};

setInterval(() => console.log(timeStrGet(new Date())), 299);



1

@Aron给出的答案有效,但是它对我不起作用,因为我尝试从1980年开始转换时间戳。因此,我进行了如下更改:

function ConvertUnixTimeToDateForLeap(UNIX_Timestamp) {
    var dateObj = new Date(1980, 0, 1, 0, 0, 0, 0);
    dateObj.setSeconds(dateObj.getSeconds() + UNIX_Timestamp);
    return dateObj;  
}

document.body.innerHTML = 'TimeStamp : ' + ConvertUnixTimeToDateForLeap(1269700200);

因此,如果您的时间戳记从另外十年开始,请使用此时间戳记。它为我省了很多头痛。

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.