สตริงวินาทีของเวลา JavaScript ที่มีรูปแบบ hh: mm: ss


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 นาที = Math.floor ((sec_num% 3600) / 60); var วินาที = Math.floor (sec_num% 60);
IvanM

3
อ่าขอบคุณ ฉันไม่เห็นว่ามันทำงานทั้งสองเป็นสตริงจนกว่าคุณจะเรียก. toString () ในจำนวนเต็ม คุณสามารถทำให้มันเป็นไปได้ด้วยวิธีการแยกวิเคราะห์ด้วย
Soul Soul

51
อย่าใส่ต้นแบบลงไปเพียงสร้างฟังก์ชันอรรถประโยชน์
Michael J. Calkins

15
ปรับเปลี่ยนต้นแบบสำหรับสิ่งนั้น โหวต 390 คะแนน? อย่างจริงจัง?
Lukas Liesis

197

คุณสามารถจัดการได้โดยไม่ต้องมีไลบรารี 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 ดังนั้นวิธีการแก้ปัญหาที่ง่ายและไม่ยุ่งยากนี้ควรจะสูงกว่านี้
Emil Borconi

2
จาก MDN: หากพารามิเตอร์ที่คุณระบุอยู่นอกช่วงที่คาดไว้ setSeconds () จะพยายามอัปเดตข้อมูลวันที่ในวัตถุวันที่ตามลำดับ ตัวอย่างเช่นหากคุณใช้ 100 เป็นวินาทีค่ามูลค่านาทีที่เก็บไว้ในวัตถุวันที่จะเพิ่มขึ้น 1 และ 40 จะใช้เป็นวินาที ใช่แล้วดูดี!
Andrew

40
ฉันชอบคำตอบนี้ มันอาจสั้นกว่านี้: new Date(1000 * seconds).toISOString().substr(11, 8).
Bohumir Zamecnik

4
คำตอบที่ดี คุณสามารถใช้.replace(/^[0:]+/, "")หลังจากsubstrเพื่อลบศูนย์ทั้งหมดและ:จากจุดเริ่มต้นของสตริง
Palo

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 () แทนที่ (/.* (\ d {2}:) (\ d {2}: \ d {2 }). * /, "$ 2") "?
obie

6
การใช้งานreplaceมีความสับสน ทำไมไม่ใช้new Date(null, null, null, null, null, timeInSeconds).toTimeString().match(/\d{2}:\d{2}:\d{2}/)[0]?
Călin Darie

4
นี่เป็นเรื่องปกติสำหรับการแสดงเวลาที่กำหนด แต่ให้สังเกตว่าคำถาม (และคำตอบอื่น ๆ ที่นี่) นั้นเกี่ยวกับการแสดงระยะเวลานั่นคือจำนวนวินาทีที่กำหนดซึ่งเป็นอิสระจากเวลาปัจจุบัน
mahemoff

4
รุ่นที่ง่ายกว่านี้:new Date().toTimeString().split(" ")[0]
Henrik N

52

ฉันแนะนำจาวาสคริปต์ธรรมดาโดยใช้วัตถุ 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 ที่สร้างขึ้นจะมีวันที่ตามจริงที่เกี่ยวข้อง แต่ข้อมูลนั้นไม่เกี่ยวข้องดังนั้นสำหรับวัตถุประสงค์เหล่านี้คุณไม่ต้องกังวลกับมัน)


ดูเหมือนว่าจะทำให้วันที่ในเขตเวลาท้องถิ่นซึ่งในกรณีของฉันเพิ่มเวลา 1 ชั่วโมง ด้วยวินาที = 0 ฉันได้รับ "01:00:00" (พฤ. 01 ม.ค. 1970 01:00:00 GMT + 0100 (CET)) ซึ่งผิด
mivk

3
ฉันจะได้รับผลที่ถูกต้องถ้าผมใช้และdate.getUTCHours() date.getUTCMinutes()
mivk

ฉันไม่เข้าใจว่าทำไมคุณส่งคืนเวลา 12 ชั่วโมงเมื่อเขาขอเวลา
Nathan C. Tresch

@JellicleCat เปลี่ยนเป็น +1 และชื่อดี
Nathan C. Tresch

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);ที่จุดเริ่มต้นของวิธีการ แน่นอนเราเห็นข้อผิดพลาดนี้ในระหว่างการสาธิต ...
เบนจามิน Crouzier

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

ขอบคุณที่ช่วยฉันประหยัดชั่วโมงนี้
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(':');
Ruben Stolk

2
@ RubenStolk ฉันรู้สึกสับสนเล็กน้อยที่จะมีฟังก์ชั่นที่รับsecondอาร์กิวเมนต์สองตัว ฉันพบเวอร์ชันของฉันที่ชัดเจนยิ่งขึ้นแม้ว่าจะเป็น verbose ที่มากกว่าเล็กน้อย
Tom Esterez

seconds: numberพิมพ์คำอธิบายประกอบใน es6 หรือไม่
Olian04

1
@pstanton ท้ายจุลภาคได้รับการสนับสนุนตั้งแต่ IE9: caniuse.com/#feat=mdn-javascript_grammar_trailing_commas ฉันเลือกที่จะเพิกเฉยต่อเบราว์เซอร์เก่าเหล่านั้นเป็นการส่วนตัว แต่คุณพูดถูกฉันเอามันออกไป
Tom Esterez

1
ทางออกที่ดี อาจแค่เปลี่ยนวินาทีเป็นconst s = Math.round(seconds % 60);
Raff

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จริงๆแล้วเป็นเรื่องของจำนวน คุณควรแปลงจากสตริงก่อนที่จะใช้ฟังก์ชั่นนี้ซึ่งเป็นสิ่งที่ถูกต้องที่จะทำ!
caesarsol

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

คำอธิบายเพิ่มเติมเกี่ยวกับสาเหตุที่คำตอบนี้ใช้ได้กับผู้ถามหรือสิ่งที่อาจผิดในคำถามเดิมจะช่วยยกระดับคุณภาพของคำตอบนี้
Josh Burgess

1
พริตตี้คำอธิบายที่ดีและอธิบายตัวเองสวยลดและลดความซับซ้อนของคำตอบด้านบน
AlexioVay

คำตอบที่แม่นยำ
:)

11

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

ผลลัพธ์ 15:08:03


ดีมาก - ขอบคุณ! และฉันปรับปรุงขนาดเล็กที่ทำสำหรับความต้องการของฉันคือการแปลงระยะเวลาในมิลลิวินาทีในการ HH: MM: SS - new Date(new Date().getTime() - startTime).toUTCString().split(" ")[4]ที่ถูกตั้งก่อนหน้าใช้startTime startTime = 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

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"


สิ่งนี้จะไม่ถูกต้องสำหรับระยะเวลา 24 วันหรือนานกว่า
Charlie Martin

ทำไมคุณเปรียบเทียบสตริงที่มากกว่า 0
Jimmy Kane

@ JimmyKane เพราะการพิมพ์อัตโนมัติ - ฉันรักมัน! (บวก: รหัสอ่านง่ายกว่า (คุณพิมพ์ผิดด้วยเหตุผล แต่ลองหยุดหมุน (เราทั้งคู่))) บวก: ฟังก์ชั่นจะล้มเหลวถ้า t เป็น NaN - ดังนั้นถ้าคุณต้องการความปลอดภัย: ทำ ที่อินพุต!)
nïkö

@ nïköตกลงฉันเข้าใจ แต่เข้มงวดมากขึ้น JS รุ่นใหม่ linters และอื่น ๆ สามารถบ่นเกี่ยวกับเรื่องนี้ แค่พูดว่าดงเข้าใจฉันผิด ฉันชอบคำตอบของคุณ
Jimmy Kane

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


ฉันมีวัตถุสองวันที่และเวลาและฉันต้องการคำนวณความแตกต่างของวัตถุ 2 วันที่นี้และผลตอบแทนเช่นในรูปแบบนี้: ชั่วโมง: นาที: วินาที: ด้วยตัวเลขสองหลักเช่น: 01: 02: 45 คุณช่วยบอกฉันหน่อยได้ไหม ด้วยรหัสของคุณ ??
Learning-Overthinker-Confused

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

ยอดเยี่ยมจริงๆ ยินดีด้วย!
Brynner Ferreira

ดี ... และ> ปลอดภัยตลอด 24 ชั่วโมง
Jeffz

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)" โปรดทราบว่าการแก้ปัญหานี้ใช้เวลาตั้งแต่ยุค: เที่ยงคืนของวันที่ 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");
}

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

หากคุณต้องการใช้-เป็นตัวคั่นเพียงแค่ส่งเป็นพารามิเตอร์ตัวที่สอง:

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.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" ฯลฯ ) เป็นตัวเลือก


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

นี่คือหนึ่งบรรทัดอัปเดตสำหรับปี 2562:

//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


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.