Maison > interface Web > js tutoriel > Comment calculer avec précision la différence de temps entre deux dates-heures à l'aide de moment.js ?

Comment calculer avec précision la différence de temps entre deux dates-heures à l'aide de moment.js ?

DDD
Libérer: 2024-11-17 11:39:01
original
406 Les gens l'ont consulté

How to Accurately Calculate the Time Difference Between Two Datetimes using moment.js?

Obtenir la différence de temps entre les dates et heures

Déterminer la différence de temps entre deux dates et heures spécifiques est une exigence courante dans de nombreuses applications. Cet article fournit un guide complet pour obtenir un intervalle de temps précis à l'aide de moment.js, en abordant les problèmes potentiels et en proposant des approches alternatives.

Énoncé du problème

Étant donné deux dates-heures représentées sous forme de chaînes, l'objectif est de calculez le décalage horaire et affichez-le au format HH:MM:SS. Par exemple :

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

//expected result:
"00:39:30"
Copier après la connexion

Tentative initiale et problème

En utilisant la fonction diff de moment.js, vous pouvez essayer ce qui suit :

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
Copier après la connexion

Cependant, cette approche ajoute de manière incorrecte 10 heures, même si les valeurs internes de la durée sont exactes.

Correct Solution

Pour résoudre ce problème, il existe deux options :

Option 1 (pour les durées inférieures à 24 heures) :

moment.utc(moment(now,"DD/MM/YYYY HH:mm:ss").diff(moment(then,"DD/MM/YYYY HH:mm:ss"))).format("HH:mm:ss")
Copier après la connexion

Cette Cette approche convertit le décalage horaire en UTC, éliminant ainsi toute incohérence de l'heure d'été.

Option 2 (pour les durées de 24 heures ou plus) :

var ms = moment(now,"DD/MM/YYYY HH:mm:ss").diff(moment(then,"DD/MM/YYYY HH:mm:ss"));
var d = moment.duration(ms);
var s = Math.floor(d.asHours()) + moment.utc(ms).format(":mm:ss");
Copier après la connexion

Cette approche calcule la différence de temps en millisecondes, la convertit en un objet de durée et extrait les heures, les minutes et les secondes séparément.

Approche alternative : moment-duration-format

Pour ceux qui recherchent une solution pratique pour formater les objets de durée, un plugin tiers appelé moment-duration-format peut être employé :

var s = d.format("hh:mm:ss");
Copier après la connexion

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal