减去日期Javascript

时间:2015-05-22 13:29:54

标签: javascript jquery timestamp milliseconds

我一直在尝试将我的时间戳格式化为facebook / twitter风格,其中显示1秒,1天,1个月,1年等等。但由于某种原因,它没有返回正确的值,我不知道为什么?

下面我已经复制了我正在使用的代码,并提供了两个减去日期的例子。

如果有人可以帮助我并指出问题以及我在显示正确值时出错的地方会很好。

// Returned Result 
$("#TimeFormatted").append("Not divided by 1000: " + FormatTimeAgo(SubtractDates("1432215738000")));
$("#TimeFormatted2").append("Divided by 1000: " + FormatTimeAgo(SubtractDates2("1432215738000")));

function FormatTimeAgo(milliseconds)
{

    function numberEnding (number) {
        return (number > 1) ? 's' : '';
    }

    var temp = Math.floor(milliseconds / 1000);
    var years = Math.floor(temp / 31536000);

    // Years ago
    if (years) {
        return years + ' year' + numberEnding(years);
    }
    
    // Days ago
    var days = Math.floor((temp %= 31536000) / 86400);
    if (days) {
        return days + ' day' + numberEnding(days);
    }

    // Hours ago
    var hours = Math.floor((temp %= 86400) / 3600);
    if (hours) {
        return hours + ' hour' + numberEnding(hours);
    }

    // Minutes ago
    var minutes = Math.floor((temp %= 3600) / 60);
    if (minutes) {
        return minutes + ' minute' + numberEnding(minutes);
    }

    // Seconds ago
    var seconds = temp % 60;
    if (seconds) {
        return seconds + ' second' + numberEnding(seconds);
    }

    return 'less than a second'; //'just now' //or other string you like;
}

function SubtractDates(databaseTime)
{
    // Current time
    var date = new Date().getTime();

    // Database value
    var mysqlDate = new Date(databaseTime);
    var getMYSQLDate = mysqlDate.getTime();
    
    // Subtract dates
    var subtractDates = date - getMYSQLDate;

    return subtractDates;
}

function SubtractDates2(databaseTime)
{
    // Current time
    var date = new Date().getTime();

    // Database value
  
    var mysqlDate2 = new Date(databaseTime / 1000);
    var getMYSQLDate2 = mysqlDate2.getTime();
  
    // Subtract dates
    var subtractDates2 = date - getMYSQLDate2;

    return subtractDates2;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>

<div id="TimeFormatted"></div>

<div id="TimeFormatted2"></div>

提前谢谢!

2 个答案:

答案 0 :(得分:1)

克里斯 -

请参阅此主题,该主题似乎可以回答您的实际问题:

Stackoverflow:Convert a Unix timestamp to time in Javascript

作为毫秒级计算的替代方法,请考虑利用Date对象的强大功能。当您减去两个日期值时,您将自1970年1月1日开始经过时间。然后您只需要将年份偏移-1970并将日期偏移-1 ...并且您拥有所需的信息。

正如Ivan Sivak指出的那样,日期很难处理...特别是当你正在处理世界时区和季节性时间变化时。当moment.js有用的时候。

无论如何,如果您想了解不同的方法,可以使用以下代码进行试验:

<!doctype html>
<html>
<body>
<div id="stdout"></div>

<script type="text/javascript">

var startDate = new Date( 1432215738000 );

setInterval( 
    function() {
        var t = new Date( new Date() - startDate ); 
        document.getElementById('stdout').innerHTML = (
            'year=' + ( t.getUTCFullYear() - 1970) + 
            ' day=' + (t.getUTCDate() - 1) + 
            ' hour=' + t.getUTCHours() + 
            ' minute=' + t.getUTCMinutes() + 
            ' seconds=' + t.getUTCSeconds()
        );
    }, 
    1000
);
</script>
</body>
</html>

答案 1 :(得分:0)

我现在觉得很傻,因为我已经回答了我自己的问题。我忘了做

Math.floor((减去时间)/ 1000);

function SubtractDates(databaseTime)
{
    // Current time
    var date = new Date().getTime();

    // Database value
    var mysqlDate = new Date(databaseTime / 1000);
    var getMYSQLDate = mysqlDate.getTime();

    // Subtract dates FIXED
    var SubtractDates = Math.floor((date - getMYSQLDate) / 1000) ;

    return SubtractDates;
}