Convert a Unix timestamp to time in JavaScript
我将时间存储在一个mysql数据库中,作为一个unix时间戳,并发送到一些javascript代码。我该怎么打发时间呢?
例如,hh/mm/ss格式。
1 2 3 4 5 6 7 8 9 10 11 12 | // 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); |
有关日期对象的更多信息,请参阅MDN或ECMAScript 5规范。
1 2 3 4 5 6 7 8 9 10 11 12 13 | 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)); |
javascript以毫秒为单位工作,因此首先必须将unix时间戳从秒转换为毫秒。
1 2 | var date = new Date(UNIX_Timestamp * 1000); // Manipulate JavaScript Date object here... |
我倾向于JacobWright的
1 | new Date(unix_timestamp * 1000).format('h:i:s') |
下面是最短的一行格式秒的解决方案,如
1 2 3 4 5 6 7 8 9 10 11 12 | /** * 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" |
Method
Date.prototype.toISOString() returns time in
simplified extended ISO 8601 format, which is always 24 or 27 characters long (i.e.YYYY-MM-DDTHH:mm:ss.sssZ or
±YYYYYY-MM-DDTHH:mm:ss.sssZ respectively). The timezone is always
zero UTC offset.
注意:此解决方案不需要任何第三方库,并且在所有现代浏览器和JavaScript引擎中都受支持。
用途:
1 2 | var s = new Date(1504095567183).toLocaleDateString("en-US") // expected output"8/30/2017" |
时间:
1 2 | var s = new Date(1504095567183).toLocaleTimeString("en-US") // expected output"3:19:27 PM"` |
请参见date.prototype.toLocaledateString()。
我会考虑使用一个像momentjs.com这样的库,这样做非常简单:
基于UNIX时间戳:
1 2 | var timestamp = moment.unix(1293683278); console.log( timestamp.format("HH/mm/ss") ); |
基于MySQL日期字符串:
1 2 | var now = moment("2010-10-10 12:03:15"); console.log( now.format("HH/mm/ss") ); |
Unix Timestamp是自1970年1月1日00:00:00 UTC以来的秒数(根据维基百科)。
javascript中日期对象的参数是1970年1月1日00:00:00 UTC以来的毫秒数(根据W3Schools javascript文档)。
例如,请参见下面的代码:
1 2 3 4 5 6 7 8 | function tm(unix_tm) { var dt = new Date(unix_tm*1000); document.writeln(dt.getHours() + '/' + dt.getMinutes() + '/' + dt.getSeconds() + ' -- ' + dt + ''); } tm(60); tm(86400); |
给予:
1 2 | 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) |
使用moment.js,您可以获得如下时间和日期:
1 | var dateTimeString = moment(1439198499).format("DD-MM-YYYY HH:mm:ss"); |
你只能用这个时间:
1 | var timeString = moment(1439198499).format("HH:mm:ss"); |
上述解决方案的问题是,如果小时、分钟或秒只有一个数字(即0-9),那么时间可能是错误的,例如,时间可能是2:3:9,但应该是02:03:09。
根据这一页,它似乎是一个更好的解决方案,使用日期的"tolocaletimestring"方法。
另一种方法-从ISO 8601日期开始。
1 2 3 4 | var timestamp = 1293683278; var date = new Date(timestamp*1000); var iso = date.toISOString().match(/(\d{2}:\d{2}:\d{2})/) alert(iso[1]); |
现在您必须使用Unix时间戳:
1 | var dateTimeString = moment.unix(1466760005).format("DD-MM-YYYY HH:mm:ss"); |
基于@shomrat的答案,这里有一个自动写入日期时间的片段(有点类似于stackoverflow的答案日期:
1 | today, 11:23 |
或
1 | yersterday, 11:23 |
或者(如果与今天不同但同一年)
1 | 6 Nov, 11:23 |
或者(如果比今天晚一年)
1 | 6 Nov 2016, 11:23 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | 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; } |
不需要40 kb库的现代解决方案:
intl.date time format是一种非文化帝国主义的日期/时间格式。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | // 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 ) ) ); |
1 2 3 4 5 6 7 8 9 10 11 12 | 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 |
我的时间戳正在从PHP后端获取。我试过上面所有的方法,但都不管用。然后我遇到了一个有用的教程:
1 2 3 4 5 6 7 8 9 10 | 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()); |
以上方法将生成此结果
1 2 3 4 5 6 7 | 1541415288860 Mon Nov 05 2018 2018 54 48 13 1:54:48 PM |
有许多方法可以与时间戳完美配合。不能全部列出
将秒格式化为hh:mm:ss:variant:
1 2 | console.log(new Date(1549312452 * 1000).toISOString().slice(0, 19).replace('T', ' ')); //"2019-02-04 20:34:12" |
注意一些答案的零问题。例如,时间戳
我建议使用以下方法来解决这个问题:
1 2 3 4 | 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); |
现在的结果是:
1 | 12/08/2015 00:49 |
1 2 3 4 5 6 7 8 9 10 11 12 13 | // 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()); |
您可以使用以下函数将时间戳转换为
1 2 3 4 5 6 7 8 9 | 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 : ':' ); } |
在不传递分隔符的情况下,它使用
1 | time = convertTime(1061351153); // --> OUTPUT = 05:45:53 |
如果要使用
1 | time = convertTime(920535115, '/'); // --> OUTPUT = 09/11/55 |
演示
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | 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 = '[cc lang="javascript"]' + JSON.stringify({ 920535115 : convertTime(920535115, '/'), 1061351153 : convertTime(1061351153, ':'), 1435651350 : convertTime(1435651350, '-'), 1487938926 : convertTime(1487938926), 1555135551 : convertTime(1555135551, '.') }, null, '\t') + ' |
';
另见这把小提琴。
请参见日期/历元转换器。
您需要
1 2 3 4 5 6 7 8 9 10 11 12 13 | 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; |
1 2 3 4 5 6 7 8 | 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; } |
如果要将Unix持续时间转换为实际小时、分钟和秒,可以使用以下代码:
1 2 3 4 | 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 2 3 4 5 6 7 | 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 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | 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 |
下面的代码还提供3位毫秒,非常适合控制台日志前缀:
1 2 3 4 5 6 | const timeStrGet = date => { const milliSecsStr = date.getMilliseconds().toString().padStart(3, '0') ; return `${date.toLocaleTimeString('it-US')}.${milliSecsStr}`; }; setInterval(() => console.log(timeStrGet(new Date())), 299); |