Строка в секундах в JavaScript с форматом чч: мм: сс

300

Я хочу преобразовать время, т. Е. Количество секунд, в строку времени, разделенную двоеточиями (чч: мм: сс)

Я нашел здесь несколько полезных ответов, но все они говорят о конвертации в формат х часов и х минут.

Так есть ли крошечный фрагмент, который делает это в jQuery или просто сырой JavaScript?

medk
источник
11
Тесты нескольких из предложенных ответов в этой теме. jsperf.com/ms-to-hh-mm-ss-time-format
Claudijo

Ответы:

583
String.prototype.toHHMMSS = function () {
    var sec_num = parseInt(this, 10); // don't forget the second param
    var hours   = Math.floor(sec_num / 3600);
    var minutes = Math.floor((sec_num - (hours * 3600)) / 60);
    var seconds = sec_num - (hours * 3600) - (minutes * 60);

    if (hours   < 10) {hours   = "0"+hours;}
    if (minutes < 10) {minutes = "0"+minutes;}
    if (seconds < 10) {seconds = "0"+seconds;}
    return hours+':'+minutes+':'+seconds;
}

Вы можете использовать его сейчас как:

alert("5678".toHHMMSS());

Рабочий фрагмент:

powtac
источник
1
Спасибо за идею прототипа, мне нравится, как это проще назвать. Я прототипировал номер, чтобы я мог назвать его на них тоже. Я также нашел этот ответ , который удалил бы часы и минуты, если бы они не были нужны.
alunsford3
21
используйте оператор "%" >> var minutes = Math.floor ((sec_num% 3600) / 60); var seconds = Math.floor (sec_num% 60);
IvanM
3
ах спасибо Я не вижу, что он работает в обоих направлениях как строка, пока вы не вызовете .toString () для целого числа Вы можете заставить его работать наоборот, анализируя int тоже
Sonic Soul
51
Не вставляйте в прототип, просто сделайте вспомогательную функцию.
Майкл Дж. Калкинс
15
модифицировать прототип для такой вещи? 390 голосов? шутки в сторону?
Лукас Лиезис
198

Вы можете сделать это без какой-либо внешней библиотеки JS с помощью метода JS Date, как показано ниже:

var date = new Date(0);
date.setSeconds(45); // specify value for SECONDS here
var timeString = date.toISOString().substr(11, 8);
console.log(timeString)

Хариш Анчу
источник
4
Почему этот ответ так низок? Я понимаю, что в 2011 году IE 7 и 8 были основой, которая не будет его поддерживать, но это конец 2014 года, так что это простое простое решение должно быть намного выше.
Эмиль Боркони
2
От MDN: если указанный вами параметр находится за пределами ожидаемого диапазона, setSeconds () пытается соответствующим образом обновить информацию о дате в объекте Date. Например, если вы используете 100 для secondsValue, минуты, сохраненные в объекте Date, будут увеличены на 1, а 40 будут использоваться для секунд. Так что да, выглядит хорошо!
Эндрю
41
Мне нравится этот ответ. Это может быть даже короче new Date(1000 * seconds).toISOString().substr(11, 8).
Богумир Замецник
4
Хороший ответ. Вы можете использовать .replace(/^[0:]+/, "")после, substrчтобы удалить все нули и :от начала строки.
Пало,
1
Добавьте это впереди, чтобы обрабатывать время более 24 часов. parseInt (d / 86400) + "d"
Tofandel
82

Чтобы получить часть времени в формате hh:MM:ss, вы можете использовать это регулярное выражение:

(Это было упомянуто выше в том же посте кем-то, спасибо за это.)

    var myDate = new Date().toTimeString().replace(/.*(\d{2}:\d{2}:\d{2}).*/, "$1");
    console.log(myDate)

Радж
источник
8
+1 - супер-простой; Спасибо! Просто использовал вариант этого, чтобы показать только минуты и секунды:var myDate = new Date().toTimeString().replace(/.*(\d{2}:\d{2})(:\d{2}).*/, "$1");
Topher Fangio
1
это не должно быть "новая Дата (ноль, ноль, ноль, ноль, ноль, времяИнсексы) .toTimeString (). replace (/.* (\ d {2}:) (\ d {2}: \ d {2 }). * /, "$ 2") "?
повиноваться
6
Использование replaceсбивает с толку. Почему бы не использовать new Date(null, null, null, null, null, timeInSeconds).toTimeString().match(/\d{2}:\d{2}:\d{2}/)[0]?
Кэлин Дари
4
Это хорошо для отображения заданного времени, но обратите внимание, что вопрос (и другие ответы здесь) касаются показа длительности, то есть заданного количества секунд, не зависящих от текущего времени.
mahemoff
4
Упрощенная версия этого:new Date().toTimeString().split(" ")[0]
Henrik N
52

Я рекомендую обычный javascript, используя объект Date:

var seconds = 9999;
// multiply by 1000 because Date() requires miliseconds
var date = new Date(seconds * 1000);
var hh = date.getUTCHours();
var mm = date.getUTCMinutes();
var ss = date.getSeconds();
// If you were building a timestamp instead of a duration, you would uncomment the following line to get 12-hour (not 24) time
// if (hh > 12) {hh = hh % 12;}
// These lines ensure you have two-digits
if (hh < 10) {hh = "0"+hh;}
if (mm < 10) {mm = "0"+mm;}
if (ss < 10) {ss = "0"+ss;}
// This formats your string to HH:MM:SS
var t = hh+":"+mm+":"+ss;
document.write(t);

(Конечно, с созданным объектом Date будет связана фактическая дата, но эти данные посторонние, поэтому в этих целях вам не нужно об этом беспокоиться.)

JellicleCat
источник
Кажется, что дата в местном часовом поясе, которая в моем случае добавляет 1 час времени. С секундами = 0 я получаю «01:00:00» (чт. 01 января 1970 г. 01:00:00 GMT + 0100 (CET)), что неверно.
mivk
3
Я получаю правильный результат, если я использую date.getUTCHours()и date.getUTCMinutes().
mivk
Я не понимаю, почему вы возвращаете 12-часовую временную метку, когда он спросил о продолжительности?
Натан С. Треш
@JellicleCat Изменилось на +1, и хорошее имя.
Натан С. Треш
1
Мне это нравится, но предполагается, что продолжительность меньше 24 часов
Рори
40

Поиск Google нашел этот результат :

function secondsToTime(secs)
{
    secs = Math.round(secs);
    var hours = Math.floor(secs / (60 * 60));

    var divisor_for_minutes = secs % (60 * 60);
    var minutes = Math.floor(divisor_for_minutes / 60);

    var divisor_for_seconds = divisor_for_minutes % 60;
    var seconds = Math.ceil(divisor_for_seconds);

    var obj = {
        "h": hours,
        "m": minutes,
        "s": seconds
    };
    return obj;
}
Эш Бурлаченко
источник
8
secondsToTime(119.9)=> Object {h: 0, m: 1, s: 60}. Чтобы исправить это, добавьте secs = Math.round(secs);в начале метода. Конечно, мы видели эту ошибку во время демонстрации ...
Бенджамин Крузье
29

Вариация на тему. Обрабатывает однозначные секунды немного по-другому

seconds2time(0)  ->  "0s" 
seconds2time(59) -> "59s" 
seconds2time(60) -> "1:00" 
seconds2time(1000) -> "16:40" 
seconds2time(4000) -> "1:06:40"

function seconds2time (seconds) {
    var hours   = Math.floor(seconds / 3600);
    var minutes = Math.floor((seconds - (hours * 3600)) / 60);
    var seconds = seconds - (hours * 3600) - (minutes * 60);
    var time = "";

    if (hours != 0) {
      time = hours+":";
    }
    if (minutes != 0 || time !== "") {
      minutes = (minutes < 10 && time !== "") ? "0"+minutes : String(minutes);
      time += minutes+":";
    }
    if (time === "") {
      time = seconds+"s";
    }
    else {
      time += (seconds < 10) ? "0"+seconds : String(seconds);
    }
    return time;
}
jottos
источник
Спасибо, что сэкономили мне час на этом
starsinmypockets
29

Вот мой взгляд на это:

function formatTime(seconds) {
  const h = Math.floor(seconds / 3600);
  const m = Math.floor((seconds % 3600) / 60);
  const s = Math.round(seconds % 60);
  return [
    h,
    m > 9 ? m : (h ? '0' + m : m || '0'),
    s > 9 ? s : '0' + s
  ].filter(Boolean).join(':');
}

Ожидаемые результаты:

const expect = require('expect');
expect(formatTime(0)).toEqual('0:00');
expect(formatTime(1)).toEqual('0:01');
expect(formatTime(599)).toEqual('9:59');
expect(formatTime(600)).toEqual('10:00');
expect(formatTime(3600)).toEqual('1:00:00');
expect(formatTime(360009)).toEqual('100:00:09');
expect(formatTime(0.2)).toEqual('0:00');
Том Эстерез
источник
Вы могли бы написать это как: const formatTime = (seconds, h = Math.floor(seconds / 3600), m = Math.floor((seconds % 3600) / 60), s = seconds % 60) => [h, m > 9 ? m : '0' + m, s > 9 ? s : '0' + s].filter(s => s).join(':');
Рубен Столк
2
@RubenStolk Я нахожу немного странным иметь функцию, которая принимает два secondаргумента. Я считаю свою версию более понятной, даже если она более многословна.
Том Эстерез
seconds: numberТип аннотации, в es6?
Olian04
1
Конечная запятая @pstanton поддерживается начиная с IE9: caniuse.com/#feat=mdn-javascript_grammar_trailing_commas . Я лично решил игнорировать эти старые браузеры сейчас. Но вы правы, я удалил его, поэтому ответ более общий.
Том Эстерез
1
Отличное решение. Может быть, просто изменить секунд, какconst s = Math.round(seconds % 60);
Рафф
16

Мне нравится первый ответ. Там несколько оптимизаций:

  • Исходными данными является номер. дополнительные расчеты не нужны.

  • много лишних вычислений

Код результата:

Number.prototype.toHHMMSS = function () {
    var seconds = Math.floor(this),
        hours = Math.floor(seconds / 3600);
    seconds -= hours*3600;
    var minutes = Math.floor(seconds / 60);
    seconds -= minutes*60;

    if (hours   < 10) {hours   = "0"+hours;}
    if (minutes < 10) {minutes = "0"+minutes;}
    if (seconds < 10) {seconds = "0"+seconds;}
    return hours+':'+minutes+':'+seconds;
}
Серж К.
источник
1
Я думаю, что эта функция является функцией, используемой во фронтэнде, и поэтому я создаю прототип String, а не Number. И число всегда может быть строкой, но не наоборот.
Powtac
3
Я думаю, что Numberэто правильно, потому что seconds, на самом деле, это число. Вы должны конвертировать из строки перед использованием этой функции, и это правильно!
Цезарсоль
2
Ответ, как и этот, плохой. Могу поспорить, вам не нужны ВСЕ номера, чтобы иметь этот метод. Не модифицируйте прототип для случайных утилит.
Лукас Лиезис
или просто прототип и сделать его функцией numToHHMMSS или strTOHHMMSS
yeahdixon
Это решение работает, пока выбранное решение генерирует 60 секунд для определенных значений.
AndroidDev
14

Используя удивительную библиотеку moment.js :

function humanizeDuration(input, units ) { 
  // units is a string with possible values of y, M, w, d, h, m, s, ms
  var duration = moment().startOf('day').add(units, input),
    format = "";

  if(duration.hour() > 0){ format += "H [hours] "; }

  if(duration.minute() > 0){ format += "m [minutes] "; }

  format += " s [seconds]";

  return duration.format(format);
}

Это позволяет вам указать любую длительность, будь то часы, минуты, секунды, мельницы, и возвращает удобочитаемую версию.

Прадип
источник
14
function formatTime(seconds) {
    return [
        parseInt(seconds / 60 / 60),
        parseInt(seconds / 60 % 60),
        parseInt(seconds % 60)
    ]
        .join(":")
        .replace(/\b(\d)\b/g, "0$1")
}
meiyang
источник
Дальнейшее объяснение того, почему этот ответ будет работать для спрашивающего или что могло быть неправильно в исходном вопросе, поможет повысить качество этого ответа.
Джош Берджесс
1
Довольно понятный и хороший ответ, упрощенный и упрощенный ответ.
AlexioVay
Точный ответ
:)
11

new Date().toString().split(" ")[4];

результат 15:08:03

Артем Киба
источник
Приятно - спасибо! И небольшое улучшение, которое я сделал для своих нужд, состояло в том, чтобы преобразовать длительность в миллисекундах в ЧЧ: ММ: СС - new Date(new Date().getTime() - startTime).toUTCString().split(" ")[4]где это startTimeбыло установлено ранее с использованием startTime = new Date().getTime();. (Я должен был использовать, toUTCString()потому что иначе время было часом.)
Ричард Уайзман
10

Это довольно легко,

function toTimeString(seconds) {
  return (new Date(seconds * 1000)).toUTCString().match(/(\d\d:\d\d:\d\d)/)[0];
}
Хунг Во
источник
Это работает, только если ваша продолжительность меньше 1 дня. Но в остальном довольно мило.
cjbarth
8
s2t=function (t){
  return parseInt(t/86400)+'d '+(new Date(t%86400*1000)).toUTCString().replace(/.*(\d{2}):(\d{2}):(\d{2}).*/, "$1h $2m $3s");
}

s2t(123456);

результат:

1d 10h 17m 36s
Энди Ву
источник
6

Мне больше всего понравился ответ Webjins, поэтому я расширил его, чтобы отображать дни с суффиксом рекламы, сделал отображение условным и включил его как суффикс в обычные секунды:

function sec2str(t){
    var d = Math.floor(t/86400),
        h = ('0'+Math.floor(t/3600) % 24).slice(-2),
        m = ('0'+Math.floor(t/60)%60).slice(-2),
        s = ('0' + t % 60).slice(-2);
    return (d>0?d+'d ':'')+(h>0?h+':':'')+(m>0?m+':':'')+(t>60?s:s+'s');
}

возвращает «3d 16:32:12» или «16:32:12» или «32:12» или «12s»

Niko
источник
Это будет неверно в течение 24 дней или дольше
Чарли Мартин
почему вы сравниваете строки больше 0?
Джимми Кейн
@JimmyKane, потому что автоматическое приведение типов - я люблю его! (плюс: код легче читать (у вас есть приведение типов по какой-то причине, но давайте прекратим троллинг (нас обоих)). плюс: функция потерпит неудачу, только если t равен NaN - поэтому, если вы хотите обеспечить безопасность: сделайте это на входе!)
nïkö
@ nïkö Хорошо, я понимаю, но более строгие новые версии JS, линтеры и т. д. могут жаловаться на это. Просто скажи, дон, пойми меня неправильно. Мне нравится ваш ответ
Джимми Кейн
6

Мне понравился ответ Powtac, но я хотел использовать его в angular.js, поэтому я создал фильтр, используя его код.

.filter('HHMMSS', ['$filter', function ($filter) {
    return function (input, decimals) {
        var sec_num = parseInt(input, 10),
            decimal = parseFloat(input) - sec_num,
            hours   = Math.floor(sec_num / 3600),
            minutes = Math.floor((sec_num - (hours * 3600)) / 60),
            seconds = sec_num - (hours * 3600) - (minutes * 60);

        if (hours   < 10) {hours   = "0"+hours;}
        if (minutes < 10) {minutes = "0"+minutes;}
        if (seconds < 10) {seconds = "0"+seconds;}
        var time    = hours+':'+minutes+':'+seconds;
        if (decimals > 0) {
            time += '.' + $filter('number')(decimal, decimals).substr(2);
        }
        return time;
    };
}])

Он функционально идентичен, за исключением того, что я добавил опциональное десятичное поле для отображения доли секунды. Используйте его так же, как и любой другой фильтр:

{{ elapsedTime | HHMMSS }} дисплеи: 01:23:45

{{ elapsedTime | HHMMSS : 3 }} дисплеи: 01:23:45.678

Мордред
источник
У меня есть два объекта datetime, и я хочу вычислить разницу этого объекта 2 datetime и вернуть результат, как в следующем формате: Час: Минуты: Секунды с двузначным числом, например: 01: 02: 45. Можете ли вы сказать мне или немного наставить меня? с твоим кодом ??
Учёный-запутанный-сбитый с толку
4

Я думаю, с точки зрения производительности это, безусловно, самый быстрый:

var t = 34236; // your seconds
var time = ('0'+Math.floor(t/3600) % 24).slice(-2)+':'+('0'+Math.floor(t/60)%60).slice(-2)+':'+('0' + t % 60).slice(-2)
//would output: 09:30:36
Рутгер ван Барен
источник
Действительно удивительным. Congrats!
Бриннер Феррейра
Хорошо ... и> 24 часа в безопасности.
Джеффз
4
function toHHMMSS(seconds) {
    var h, m, s, result='';
    // HOURs
    h = Math.floor(seconds/3600);
    seconds -= h*3600;
    if(h){
        result = h<10 ? '0'+h+':' : h+':';
    }
    // MINUTEs
    m = Math.floor(seconds/60);
    seconds -= m*60;
    result += m<10 ? '0'+m+':' : m+':';
    // SECONDs
    s=seconds%60;
    result += s<10 ? '0'+s : s;
    return result;
}

Примеры

    toHHMMSS (111); 
    «1:51»

    toHHMMSS (4444);
    «1:14:04»

    toHHMMSS (33);
    "00:33"
Маши
источник
Я бы поставил Math.floor()и секунды, поскольку они могут быть указаны в десятичных числах. (Случилось со мной.)
Зима,
3

Вот еще одна версия, которая также обрабатывает дни:

function FormatSecondsAsDurationString( seconds )
{
    var s = "";

    var days = Math.floor( ( seconds / 3600 ) / 24 );
    if ( days >= 1 )
    {
        s += days.toString() + " day" + ( ( days == 1 ) ? "" : "s" ) + " + ";
        seconds -= days * 24 * 3600;
    }

    var hours = Math.floor( seconds / 3600 );
    s += GetPaddedIntString( hours.toString(), 2 ) + ":";
    seconds -= hours * 3600;

    var minutes = Math.floor( seconds / 60 );
    s += GetPaddedIntString( minutes.toString(), 2 ) + ":";
    seconds -= minutes * 60;

    s += GetPaddedIntString( Math.floor( seconds ).toString(), 2 );

    return s;
}

function GetPaddedIntString( n, numDigits )
{
    var nPadded = n;
    for ( ; nPadded.length < numDigits ; )
    {
        nPadded = "0" + nPadded;
    }

    return nPadded;
}
М Кац
источник
3

Регулярное выражение можно использовать для сопоставления временной подстроки в строке, возвращаемой toString()методом объекта Date, который отформатирован следующим образом: «Чт, 05 июля 2012 02:45:12 GMT + 0100 (GMT Daylight Time)». Обратите внимание, что в этом решении используется время, прошедшее с эпохи: полночь 1 января 1970 года. Это решение может быть однострочным, хотя его разделение облегчает понимание.

function secondsToTime(seconds) {
    const start = new Date(1970, 1, 1, 0, 0, 0, 0).getTime();
    const end = new Date(1970, 1, 1, 0, 0, parseInt(seconds), 0).getTime();
    const duration = end - start;

    return new Date(duration).toString().replace(/.*(\d{2}:\d{2}:\d{2}).*/, "$1");
}
Ninjakannon
источник
2

Вот как я это сделал. Кажется, это работает довольно хорошо, и это очень компактно. (Хотя использует много троичных операторов)

function formatTime(seconds) {
  var hh = Math.floor(seconds / 3600),
    mm = Math.floor(seconds / 60) % 60,
    ss = Math.floor(seconds) % 60;
  return (hh ? (hh < 10 ? "0" : "") + hh + ":" : "") + ((mm < 10) && hh ? "0" : "") + mm + ":" + (ss < 10 ? "0" : "") + ss
}

... и для форматирования строк ...

String.prototype.toHHMMSS = function() {
  formatTime(parseInt(this, 10))
};
rookie1024
источник
2

Вы можете использовать следующую функцию для преобразования времени (в секундах) в HH:MM:SSформат:

var convertTime = function (input, separator) {
    var pad = function(input) {return input < 10 ? "0" + input : input;};
    return [
        pad(Math.floor(input / 3600)),
        pad(Math.floor(input % 3600 / 60)),
        pad(Math.floor(input % 60)),
    ].join(typeof separator !== 'undefined' ?  separator : ':' );
}

Не передавая разделитель, он использует :(по умолчанию) разделитель:

time = convertTime(13551.9941351); // --> OUTPUT = 03:45:51

Если вы хотите использовать -в качестве разделителя, просто передайте его как второй параметр:

time = convertTime(1126.5135155, '-'); // --> OUTPUT = 00-18-46

демонстрация

var convertTime = function (input, separator) {
    var pad = function(input) {return input < 10 ? "0" + input : input;};
    return [
        pad(Math.floor(input / 3600)),
        pad(Math.floor(input % 3600 / 60)),
        pad(Math.floor(input % 60)),
    ].join(typeof separator !== 'undefined' ?  separator : ':' );
}

document.body.innerHTML = '<pre>' + JSON.stringify({
    5.3515555 : convertTime(5.3515555),
    126.2344452 : convertTime(126.2344452, '-'),
    1156.1535548 : convertTime(1156.1535548, '.'),
    9178.1351559 : convertTime(9178.1351559, ':'),
    13555.3515135 : convertTime(13555.3515135, ',')
}, null, '\t') +  '</pre>';

Смотрите также эту скрипку .

Джон Слегерс
источник
1

Вот как я это сделал

function timeFromSecs(seconds)
{
    return(
    Math.floor(seconds/86400)+'d :'+
    Math.floor(((seconds/86400)%1)*24)+'h : '+
    Math.floor(((seconds/3600)%1)*60)+'m : '+
    Math.round(((seconds/60)%1)*60)+'s');
}

timeFromSecs (22341938) вернет '258d 14h 5m 38s'

dt192
источник
1

Я лично предпочитаю ведущую единицу (дни, часы, минуты) без ведущих нулей. Но секунды всегда должны идти за минутами (0:13), это представление легко считать «продолжительностью», без каких-либо дополнительных пояснений (помечая как min, sec (s) и т. Д.), Используемое на разных языках (интернационализация).

    // returns  (-)d.h:mm:ss(.f)
    //          (-)h:mm:ss(.f)
    //          (-)m:ss(.f)
    function formatSeconds (value, fracDigits) {
        var isNegative = false;
        if (isNaN(value)) {
            return value;
        } else if (value < 0) {
            isNegative = true;
            value = Math.abs(value);
        }
        var days = Math.floor(value / 86400);
        value %= 86400;
        var hours = Math.floor(value / 3600);
        value %= 3600;
        var minutes = Math.floor(value / 60);
        var seconds = (value % 60).toFixed(fracDigits || 0);
        if (seconds < 10) {
            seconds = '0' + seconds;
        }

        var res = hours ? (hours + ':' + ('0' + minutes).slice(-2) + ':' + seconds) : (minutes + ':' + seconds);
        if (days) {
            res = days + '.' + res;
        }
        return (isNegative ? ('-' + res) : res);
    }

// имитация форматирования продолжительности на стороне сервера (.net, C #), например:

    public static string Format(this TimeSpan interval)
    {
        string pattern;
        if (interval.Days > 0)          pattern = @"d\.h\:mm\:ss";
        else if (interval.Hours > 0)    pattern = @"h\:mm\:ss";
        else                            pattern = @"m\:ss";
        return string.Format("{0}", interval.ToString(pattern));
    }
Питер Цендер
источник
1

Вы можете использовать Momement.js с плагином форматом момент-длительности :

var seconds = 3820;
var duration = moment.duration(seconds, 'seconds');
var formatted = duration.format("hh:mm:ss");
console.log(formatted); // 01:03:40
<!-- Moment.js library -->
<script src="https://cdnjs.cloudflare.com/ajax/libs/moment.js/2.18.1/moment.min.js"></script>

<!-- moment-duration-format plugin -->
<script src="https://cdnjs.cloudflare.com/ajax/libs/moment-duration-format/1.3.0/moment-duration-format.min.js"></script>

Смотрите также эту скрипку

Алексей Качинский
источник
Работает как талисман (за исключением формата, который не определен) для преобразования продолжительности объекта с месяцами, днями, часами, минутами и секундами
Pi Home Server
1

const secondsToTime = (seconds, locale) => {
    const date = new Date(0);
    date.setHours(0, 0, seconds, 0);
    return date.toLocaleTimeString(locale);
}
console.log(secondsToTime(3610, "en"));

где параметр locale ("en", "de" и т. д.) является необязательным

JukkaP
источник
1
secToHHMM(number: number) {
    debugger;
    let hours = Math.floor(number / 3600);
    let minutes = Math.floor((number - (hours * 3600)) / 60);
    let seconds = number - (hours * 3600) - (minutes * 60);
    let H, M, S;
    if (hours < 10) H = ("0" + hours);
    if (minutes < 10) M = ("0" + minutes);
    if (seconds < 10) S = ("0" + seconds);
    return (H || hours) + ':' + (M || minutes) + ':' + (S || seconds);
}
Израиль
источник
1

Вот обновленный однострочник для 2019 года:

//your date
var someDate = new Date("Wed Jun 26 2019 09:38:02 GMT+0100") 

var result = `${String(someDate.getHours()).padStart(2,"0")}:${String(someDate.getMinutes()).padStart(2,"0")}:${String(someDate.getSeconds()).padStart(2,"0")}`

//result will be "09:38:02"
DataGreed
источник
Я думаю, что ОП хочет преобразовать длительность (секунды), а не Dateобъект.
Мрдалири
ой, мой плохой :(
DataGreed
1

Вот довольно простое решение, которое округляется до ближайшей секунды!

var returnElapsedTime = function(epoch) {
  //We are assuming that the epoch is in seconds
  var hours = epoch / 3600,
      minutes = (hours % 1) * 60,
      seconds = (minutes % 1) * 60;
  return Math.floor(hours) + ":" + Math.floor(minutes) + ":" + Math.round(seconds);
}

CommandoScorch
источник
1

Это тот, который я недавно написал для MM: SS. Это не точный вопрос, но это другой формат одной строки.

const time = 60 * 2 + 35; // 2 minutes, 35 seconds
const str = (~~(time / 60) + "").padStart(2, '0') + ":" + (~~((time / 60) % 1 * 60) + "").padStart(2, '0');

str // 02:35

Изменить: это было добавлено для разнообразия, но лучшее решение здесь https://stackoverflow.com/a/25279399/639679 ниже.

Мэтт Кенефик
источник