我知道我可以做任何事情,还有一些更复杂的约会。但令人尴尬的是,我在尝试做一些看似简单的事情时遇到了困难:得到2倍之间的差异。

例子:

var now  = "04/09/2013 15:00:00";
var then = "04/09/2013 14:20:30";

//expected result:
"00:39:30"

我所做的:

var now = moment("04/09/2013 15:00:00");
var then = moment("04/09/2013 14:20:30");

console.log(moment(moment.duration(now.diff(then))).format("hh:mm:ss"))
//outputs 10:39:30  

我不明白这里的“10”是什么。我住在巴西,所以我们是utc-0300。

moment.duration(now.diff(then))的结果是一个具有正确内部值的持续时间:

 days: 0
 hours: 0
 milliseconds: 0
 minutes: 39
 months: 0
 seconds: 30
 years: 0

所以,我想我的问题是:如何将一个momentjs Duration转换为一个时间间隔?我肯定可以用

duration.get("hours") +":"+ duration.get("minutes") +:+ duration.get("seconds")

但我觉得有一些更优雅的东西,我完全错过了。

更新 仔细看,在上面的例子中是:

Tue Apr 09 2013 15:00:00 GMT-0300 (E. South America Standard Time)…}

而moment(moment.duration(now.diff(then)))为:

Wed Dec 31 1969 22:39:30 GMT-0200 (E. South America Daylight Time)…}

我不确定为什么第二个值在夏令时(-0200)…但我确定我不喜欢约会:(

更新2

好吧,这个值是-0200,可能是因为31/12/1969是使用日光时间的日期……就是这样。


当前回答

这将返回最大的时间周期差异,如(4秒,2分钟,1小时,2天,3周,4个月,5年)。 我用这个来通知最近的时间。

function dateDiff(startDate, endDate) {
    let arrDate = ["seconds", "minutes", "hours", "days", "weeks", "months", "years"];
    let dateMap = arrDate.map(e => moment(endDate).diff(startDate, e));
    let index = 6 - dateMap.filter(e => e == 0).length;
    return {
        type: arrDate[index] ?? "seconds",
        value: dateMap[index] ?? 0
    };
}

例子:

dateDiff("2021-06-09 01:00:00", "2021-06-09 04:01:01")

{type: "hours", value: 3}

dateDiff("2021-06-09 01:00:00", "2021-06-12 04:01:01")

{type: "days", value: 3}

dateDiff("2021-06-09 01:00:00", "2021-06-09 01:00:10")

{type: "seconds", value: 10}

其他回答

这是非常简单的时刻 下面的代码将返回与当前时间的小时差:

moment().diff('2021-02-17T14:03:55.811000Z', "h")

当调用diff时,moment.js以毫秒为单位计算差异。 如果将毫秒值传递给duration,则使用它来计算正确的持续时间。 然而。当您将相同的毫秒传递给moment()时,它会计算从1970年1月1日(UTC/GMT午夜)的epoch/unix时间(之后)的毫秒数。 这就是为什么你把1969年算错了时间。

duration.get("hours") +":"+ duration.get("minutes") +":"+ duration.get("seconds")

所以,我认为这是你应该这样做,因为moment.js不提供持续时间的格式函数。或者你可以写一个简单的包装器使它更容易/更漂亮。

你的问题是在格式化moment.duration()之前将结果传递回moment();这将导致moment()将其解释为相对于Unix epoch的时间。

它并没有给你你想要的格式,但是

moment.duration (now.diff(当时).humanize ()

会给你一个有用的格式,比如“40分钟”。如果你真的热衷于特定的格式,你必须自己构建一个新的字符串。一个便宜的方法是

[diff.asHours (), diff.minutes (), diff.seconds ()] . join(“:”)

var diff = moment.duration(now.diff(then))。这不会给你个位数值的零填充。为此,您可能需要考虑使用下划线之类的东西。字符串——尽管它看起来有很长的路要走,只是为了多几个0。:)

Typescript:以下应该工作,

export const getTimeBetweenDates = ({
  until,
  format
}: {
  until: number;
  format: 'seconds' | 'minutes' | 'hours' | 'days';
}): number => {
  const date = new Date();
  const remainingTime = new Date(until * 1000);
  const getFrom = moment([date.getUTCFullYear(), date.getUTCMonth(), date.getUTCDate()]);
  const getUntil = moment([remainingTime.getUTCFullYear(), remainingTime.getUTCMonth(), remainingTime.getUTCDate()]);
  const diff = getUntil.diff(getFrom, format);
  return !isNaN(diff) ? diff : null;
};

要获得两分钟格式日期或javascript日期格式无差异分钟的最优解决方案

const timeDiff = moment.duration((moment(apptDetails.end_date_time).diff(moment(apptDetails.date_time)))).asMinutes()

你可以通过替换asMinutes()函数来改变不同的格式