hh:mm:ss形式の文字列をJavaScriptで秒単位で時間


300

時間の長さ、つまり秒数をコロンで区切られた時間文字列(hh:mm:ss)に変換したい

私はここでいくつかの有用な答えを見つけましたが、それらはすべてx時間とx分形式への変換について話します。

それで、jQueryでこれを実行する小さなスニペットまたは単なるJavaScriptはありますか?


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());

作業スニペット:


1
プロトタイプのアイデアのおかげで、私はそれをより簡単に呼び出すことができるのが好きです。私はそれらを呼び出すことができるように、ナンバーをプロトタイプ化しました。また、必要がなければ時間と分を削除するこの回答も見つけました。
alunsford3

21
「%」演算子を使用>> var minutes = Math.floor((sec_num%3600)/ 60); var seconds = Math.floor(sec_num%60);
IvanM 2014年

3
ああ、ありがとう。整数に対して.toString()を呼び出すまで、文字列として両方の方法で機能することはありません。intも解析することで、逆に機能させることができます
Sonic Soul

51
プロトタイプを入れずに、ユーティリティ関数を作成します。
Michael J. Calkins、2015年

15
そのようなもののプロトタイプを変更しますか?390票?本気?
Lukas Liesis

197

次のようなJS Dateメソッドを使用して、外部JSライブラリなしでこれを行うことができます。

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年の終わりなので、この単純でプレーンで大騒ぎのないソリューションはもっと高いはずです。
Emil Borconi 14

2
MDNから:指定したパラメーターが予期された範囲外の場合、setSeconds()はそれに応じてDateオブジェクトの日付情報を更新しようとします。たとえば、secondsValueに100を使用すると、Dateオブジェクトに格納されている分は1ずつ増加し、40は秒に使用されます。そうそう、よさそうだ!
アンドリュー

40
私はこの答えが好きです。さらに短くすることもできますnew Date(1000 * seconds).toISOString().substr(11, 8)
Bohumir Zamecnik 2016

4
素敵な答え。.replace(/^[0:]+/, "")after 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
「新しい日付(null、null、null、null、null、timeInSecs).toTimeString()。replace(/.*(\ d {2}:)(\ d {2}:\ d {2 })。* /、 "$ 2") "?
2013

6
の使用replaceは紛らわしいです。なぜ使用しないのnew Date(null, null, null, null, null, timeInSeconds).toTimeString().match(/\d{2}:\d{2}:\d{2}/)[0]ですか?
CALINダリエー

4
これは、特定の時間を表示するのには問題ありませんが、質問(および他のここでの回答)は、持続時間、つまり現在の時間とは無関係の特定の秒数を表示することに関するものであることに注意してください。
mahemoff 2014

4
これのより簡単なバージョン:new Date().toTimeString().split(" ")[0]
Henrik N

52

Dateオブジェクトを使用して、通常のJavaScriptをお勧めします。

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オブジェクトには実際の日付が関連付けられますが、そのデータは無関係であるため、これらの目的のために心配する必要はありません。)


現地のタイムゾーンで日付を作成しているようですが、私の場合は1時間追加されます。seconds = 0の場合、「01:00:00」(1970年1月1日木曜日01:00:00 GMT + 0100(CET))が返されますが、これは誤りです。
mivk 2013年

3
とを使用するdate.getUTCHours()と、正しい結果が得られますdate.getUTCMinutes()
mivk 2013年

彼が期間を要求したときに12時間のタイムスタンプを返す理由がわかりませんか?
Nathan C. Tresch 2015年

@JellicleCat +1に変更されました。
Nathan C. Tresch 2015年

1
私はこれが好きですが、期間が24時間未満であることを前提としています
Rory

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);は、メソッドの最初に追加します。もちろん、デモ中にこのバグを見ました...
Benjamin Crouzier 2013年

29

テーマによるバリエーション。1桁の秒の処理が少し異なります

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;
}

これで1時間節約してくれてありがとう
starsinmypockets 2013年

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(':');
ルーベンStolk

2
@RubenStolk 2つのsecond引数を取る関数があると少し混乱します。私は自分のバージョンが少し冗長であっても、より明確だと思います。
トムエステレス

seconds: number型注釈、es6?
Olian04

1
@pstanton末尾のコンマはIE9以降でサポートされています:caniuse.com/#feat=mdn-javascript_grammar_trailing_commas。私は今これらの古いブラウザを無視することにしました。しかし、あなたは正しい、私はそれを削除したので、答えはより一般的です。
Tom Esterez

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
この関数は前面で使用される機能だと思うので、NumberではなくStringのプロトタイプを作成します。また、Numberは常に文字列にすることができますが、逆はできません。
powtac 2012年

3
実は数字なNumberので正しいと思いますseconds。この関数を使用する前に文字列から変換する必要があります。これは正しいことです!
caesarsol 2013

2
これと同じように、賛成投票は悪いです。この方法では、すべての数値は必要ありません。ランダムユーティリティ関連のプロトタイプを変更しないでください。
Lukas Liesis

またはプロトタイプを作成してそれを関数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")
}

この回答が質問者に役立つ理由、または元の質問の何が間違っていたのかをさらに説明すると、この回答の質が向上します。
ジョシュバージェス

1
かなり自己説明的で良い答えで、上の答えを減らして単純化しました。
AlexioVay 2017

正確な回答:)
Rishav Kumar

11

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

結果 15:08:03


よかった、ありがとう!MM: - SSと私は私のニーズのために作られた小さな改善はHHにミリ秒単位で期間を変換することでした使用して、以前に設定しました。(それ以外の場合は時間が1時間だったので、私は使用しなければなりませんでした。)new Date(new Date().getTime() - startTime).toUTCString().split(" ")[4]startTimestartTime = new Date().getTime();toUTCString()
Richard Wiseman

10

とても簡単です

function toTimeString(seconds) {
  return (new Date(seconds * 1000)).toUTCString().match(/(\d\d:\d\d:\d\d)/)[0];
}

これは、期間が1日未満の場合にのみ機能します。しかし、それ以外の場合、かなりいいです。
cjbarth 2015年

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

私はWebjinが最も答えるのが好きだったので、広告サフィックスで日を表示するように拡張し、表示を条件付きにし、プレーン秒のサフィックスとして含めました:

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」を返します


これは24日以上の期間では正しくありません
Charlie Martin

0より大きい文字列を比較するのはなぜですか?
ジミー・ケイン

@JimmyKaneは自動型キャストのため-ほらほら!(プラス:コードの方が読みやすいです(理由のために型キャストがありますが、トローリングは止めましょう(私たち2人))。プラス:関数が失敗するのは、tがNaNの場合のみです。したがって、セキュリティが必要な場合は、次のようにします。入力でそれを!)
nïkö

@nïköOkわかりましたが、より厳密な新しい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;
    };
}])

小数秒を表示するためにオプションのdecimalsフィールドを追加したことを除いて、機能的には同じです。他のフィルターと同じように使用します。

{{ elapsedTime | HHMMSS }} 表示: 01:23:45

{{ elapsedTime | HHMMSS : 3 }} 表示: 01:23:45.678


2つの日時オブジェクトがあり、この2つの日時オブジェクトの差を計算して、次の形式のように出力を返したい:時間:分:秒のような2桁の数字:01:02:45教えてください、または少し教えてください。あなたのコードで??
ラーニングオーバーシンカー


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); 
    「01:51」

    toHHMMSS(4444);
    「01: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オブジェクトのメソッドから返される文字列の時間部分文字列を照合できます。これは、「Thu Jul 05 2012 02:45:12 GMT + 0100(GMT Daylight Time)」の形式です。このソリューションはエポックからの時間を使用していることに注意してください:1970年1月1日の午前0時。

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");
}

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))
};

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

-セパレータとして使用したい場合は、2番目のパラメータとして渡します。

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」を返します


1

個人的には、先行ゼロなしの先行単位(日、時間、分)を好みます。しかし、秒は常に分(0:13)で先行する必要があります。このプレゼンテーションは、さまざまな言語で使用できる(国際化)ので、これ以上の説明(分、秒などのマークが付けられていない)なしで「継続時間」と簡単に見なされます。

    // 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.jsmoment-duration-formatプラグインで使用できます。

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>

このフィドルも参照してください


チャームのように機能し(定義されていない形式を除く)、オブジェクトの期間を月、日、時間、分、秒で変換し
ます

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"));

ロケールパラメータ( "en"、 "de"など)はオプションです。


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"

OP はオブジェクトではなく期間(秒)を変換したいと思いDateます。
mrdaliri

oops、my bad :(
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);
}


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です。

弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.