Подтвердить что ты не робот

Преобразование миллисекунд в минуты и секунды с помощью Javascript

Soundcloud API дает длительность треков в миллисекундах. JSON выглядит так:

"duration": 298999

Я пробовал много функций, которые я нашел здесь безрезультатно. Я просто ищу что-то, чтобы преобразовать это число в нечто похожее на следующее:

4:59

Здесь тот, кто подошел, но не работает. Он не останавливает секунд на 60. Он идет до 99, что не имеет смысла. Попробуйте ввести "187810" как значение мс, например.

var ms = 298999,
min = Math.floor((ms/1000/60) << 0),
sec = Math.floor((ms/1000) % 60);

console.log(min + ':' + sec);

Спасибо за вашу помощь!

Если бы вы могли добавить поддержку в течение нескольких часов, я был бы признателен.

4b9b3361

Ответ 1

function millisToMinutesAndSeconds(millis) {
  var minutes = Math.floor(millis / 60000);
  var seconds = ((millis % 60000) / 1000).toFixed(0);
  return minutes + ":" + (seconds < 10 ? '0' : '') + seconds;
}

millisToMinutesAndSeconds(298999); // "4:59"
millisToMinutesAndSeconds(60999);  // "1:01"

Поскольку пользователь HelpingHand указал в комментариях, оператор return должен быть

return (секунды == 60? (минуты + 1) + ": 00": минуты + ":" + (секунды <10? "0": "") + секунды);

Ответ 2

var ms = 298999;
ms = 1000*Math.round(ms/1000); // round to nearest second
var d = new Date(ms);
console.log( d.getUTCMinutes() + ':' + d.getUTCSeconds() ); // "4:59"

Кроме того, если вы хотите использовать часы, используйте d.getUTCHours().

Ответ 3

Вероятно, есть лучший способ сделать это, но он выполняет свою работу:

var ms = 298999;
var min = ms / 1000 / 60;
var r = min % 1;
var sec = Math.floor(r * 60);
if (sec < 10) {
    sec = '0'+sec;
}
min = Math.floor(min);
console.log(min+':'+sec);

Не знаете, почему у вас есть оператор << на вашей минутной линии, я не думаю, что ему нужно было всего лишь за пол до того, как вы покажете.

Получение оставшейся части минут с% дает вам процент секунд, прошедших в эту минуту, поэтому умножение на 60 дает вам количество секунд и пол, что делает его более подходящим для отображения, хотя вы также можете получить точность в секунду, если вы хотеть.

Если секунд меньше 10, вы хотите отобразить их с начальным нулем.

Ответ 4

Событие, однако, oment.js не предоставляет такую функциональность, если вы придете сюда, и вы уже используете moment.js, попробуйте следующее:

function formatDuration(ms) {
  var duration = moment.duration(ms);
  return Math.floor(duration.asHours()) + moment.utc(duration.asMilliseconds()).format(":mm:ss");
}

Вы получите что-то вроде x: xx: xx.

В случае, если вы можете пропустить час, когда продолжительность составляет всего 60 минут.

function formatDuration(ms) {
  var duration = moment.duration(ms);
  if (duration.asHours() > 1) {
    return Math.floor(duration.asHours()) + moment.utc(duration.asMilliseconds()).format(":mm:ss");
  } else {
    return moment.utc(duration.asMilliseconds()).format("mm:ss");
  }
}

Этот обходной момент в момент был введен в этом выпуске.

Ответ 5

Вот мой вклад, если вы ищете

h:mm:ss

вместо этого, как я был:

function msConversion(millis) {
  let sec = Math.floor(millis / 1000);
  let hrs = Math.floor(sec / 3600);
  sec -= hrs * 3600;
  let min = Math.floor(sec / 60);
  sec -= min * 60;

  sec = '' + sec;
  sec = ('00' + sec).substring(sec.length);

  if (hrs > 0) {
    min = '' + min;
    min = ('00' + min).substring(min.length);
    return hrs + ":" + min + ":" + sec;
  }
  else {
    return min + ":" + sec;
  }
}

Ответ 6

Лучше всего это!

function msToTime(duration) {
var milliseconds = parseInt((duration%1000))
    , seconds = parseInt((duration/1000)%60)
    , minutes = parseInt((duration/(1000*60))%60)
    , hours = parseInt((duration/(1000*60*60))%24);

hours = (hours < 10) ? "0" + hours : hours;
minutes = (minutes < 10) ? "0" + minutes : minutes;
seconds = (seconds < 10) ? "0" + seconds : seconds;

return hours + ":" + minutes + ":" + seconds + "." + milliseconds;
}

Он вернется 00: 04: 21.223 Вы можете отформатировать эту строку тогда, как пожелаете.

Ответ 7

этот код будет работать лучше, если вы хотите показывать часы, а также секунды или миллисекунды после секунд, например 1: 02: 32.21, и если они используются в сотовом телефоне, таймер будет показывать правильное время даже после блокировки экрана.

<div id="timer" style="font-family:monospace;">00:00<small>.00</small></div>

<script>
var d = new Date();
var n = d.getTime();
var startTime = n;

var tm=0;
function updateTimer(){
  d = new Date();
  n = d.getTime();
  var currentTime = n;  
  tm = (currentTime-startTime);
  
  //tm +=1; 
  // si el timer cuenta en centesimas de segundo
  //tm = tm*10;
  
  var hours = Math.floor(tm / 1000 / 60 / 60);
  var minutes = Math.floor(tm / 60000) % 60;
  var seconds =  ((tm / 1000) % 60);
  // saca los decimales ej 2 d{0,2}
  var seconds = seconds.toString().match(/^-?\d+(?:\.\d{0,-1})?/)[0];
  var miliseconds = ("00" + tm).slice(-3);
  var centiseconds;

  
  // si el timer cuenta en centesimas de segundo
  //tm = tm/10;


  centiseconds = miliseconds/10;
  centiseconds = (centiseconds).toString().match(/^-?\d+(?:\.\d{0,-1})?/)[0];

  minutes = (minutes < 10 ? '0' : '') + minutes;
  seconds = (seconds < 10 ? '0' : '') + seconds;
  centiseconds = (centiseconds < 10 ? '0' : '') + centiseconds;
  hours = hours + (hours > 0 ? ':' : '');
  if (hours==0){
    hours='';
  }

  document.getElementById("timer").innerHTML = hours + minutes + ':' + seconds + '<small>.' + centiseconds + '</small>';
}

var timerInterval = setInterval(updateTimer, 10);
// clearInterval(timerInterval);
</script>