Me encantó la respuesta de Powtac, pero quería usarla en angular.js, así que creé un filtro usando su código.
.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;
};
}])
Es funcionalmente idéntico, excepto que agregué un campo de decimales opcional para mostrar segundos fraccionarios. Úselo como lo haría con cualquier otro filtro:
{{ elapsedTime | HHMMSS }}
muestra: 01:23:45
{{ elapsedTime | HHMMSS : 3 }}
muestra: 01:23:45.678