毫秒转换为易读时长格式:时:分:秒(时分秒)

在许多开发场景中,后端接口返回的数据常常是以毫秒为单位的时间戳或持续时长。而在前端展示时,我们通常需要将这些毫秒数转换成更易读的时长格式,通常采用“时:分:秒”的形式(例如 00:05:20)。为了实现这一功能,可以编写一个封装函数来进行毫秒到时分秒格式的转换。

本文将介绍如何封装一个简洁的 JavaScript 函数,用于将毫秒数转换为时长格式,并优化该函数的性能和易用性。

1、目标

假设后台返回的是毫秒数(例如:320000 毫秒),我们需要将其转换为时长格式并以 HH:mm:ss(小时:分钟:秒)的形式显示。例如:

  • 320000 毫秒应转换为 00:05:20

2、基本的毫秒转换函数

首先,我们先来看一个基础的函数实现。该函数接收一个毫秒数,并将其转换为时、分、秒格式。

const getMilliSecond = (milliseconds) => {
    // 将毫秒转换为秒
    let totalSeconds = parseInt(milliseconds / 1000);

    // 计算小时数
    let hours = parseInt(totalSeconds / 3600); // 每小时 3600 秒
    totalSeconds = totalSeconds % 3600; // 计算剩余秒数

    // 计算分钟数
    let minutes = parseInt(totalSeconds / 60); // 每分钟 60 秒
    let seconds = totalSeconds % 60; // 剩余秒数

    // 格式化小时、分钟、秒数
    let result = '';
    
    // 补零处理
    if (hours < 10) {
        result += '0' + hours + ':';
    } else {
        result += hours + ':';
    }

    if (minutes < 10) {
        result += '0' + minutes + ':';
    } else {
        result += minutes + ':';
    }

    if (seconds < 10) {
        result += '0' + seconds;
    } else {
        result += seconds;
    }

    return result;
};

// 测试
let time = getMilliSecond(320000);
console.log(time); // 输出: 00:05:20

3、代码解析

  1. 将毫秒转换为秒数

    • parseInt(milliseconds / 1000):将毫秒转换为秒,parseInt 用于去除小数部分。
  2. 计算小时、分钟和秒数

    • 使用整除 (/) 和取余 (%) 运算符将总秒数转换为小时、分钟和秒数。
    • 例如,1 小时 = 3600 秒,1 分钟 = 60 秒。
  3. 格式化输出

    • 通过条件判断来判断小时、分钟、秒数是否小于 10,如果小于 10,则在前面补充零。
    • 最终输出格式为 HH:mm:ss

4、优化与增强

1. 更精确的参数处理

当前函数处理了小时、分钟和秒数的基本逻辑,但它在输入非常小(例如几秒钟)或非常大的毫秒数时可能会出现一些不必要的行为。为了确保它对极限情况的处理更加鲁棒,我们可以增强函数的稳定性:

  • 避免负数:如果传入的毫秒数为负值,应该返回一个默认的“00:00:00”。
  • 避免无效的输入:可以对非数字类型的输入进行校验。
2. 提高代码的可读性和简洁性

我们可以使用 ES6 的 String.prototype.padStart() 方法来简化补零的过程,避免手动拼接字符串,进一步提高代码的简洁性。

5、改进后的函数

const getMilliSecond = (milliseconds) => {
    // 先判断输入是否合法
    if (isNaN(milliseconds) || milliseconds < 0) {
        return "00:00:00"; // 如果输入无效,则返回默认时间
    }

    // 将毫秒转换为秒
    let totalSeconds = Math.floor(milliseconds / 1000);

    // 计算小时、分钟、秒
    let hours = Math.floor(totalSeconds / 3600);
    let minutes = Math.floor((totalSeconds % 3600) / 60);
    let seconds = totalSeconds % 60;

    // 使用 padStart 简化补零操作
    return [
        hours.toString().padStart(2, '0'),
        minutes.toString().padStart(2, '0'),
        seconds.toString().padStart(2, '0')
    ].join(':');
};

// 测试
console.log(getMilliSecond(320000)); // 00:05:20
console.log(getMilliSecond(5000));   // 00:00:05
console.log(getMilliSecond(-1000));  // 00:00:00
console.log(getMilliSecond(0));      // 00:00:00
console.log(getMilliSecond(3600000)); // 01:00:00

6、改进说明

  1. Math.floor():替换 parseInt,确保四舍五入问题不再出现。
  2. padStart():用 padStart(2, '0') 方法来简化补零的代码,避免手动拼接。
  3. 输入验证:添加了输入校验,确保只有非负数的有效数字能够参与计算。若输入无效(如负数或非数字),则返回 "00:00:00"。

7、性能优化

对于非常大的毫秒数,尽管该函数已经进行了一些基础优化,但对于需要处理大量数据或长时间运行的应用(例如计时器或统计时长的应用),我们仍然需要考虑性能:

  • 避免不必要的计算:如果传入的毫秒数非常大,可能涉及多个小时以上,仍然可以使用简单的算数运算,不需要过多的逻辑判断。
  • 缓存结果:如果在应用中频繁调用该函数,可以考虑缓存转换结果,避免重复计算。

8、应用场景

该毫秒转换函数适用于多个场景:

  • 计时器:如在线竞赛、倒计时器。
  • 视频时长:如播放视频时显示已播放时长。
  • 任务时长统计:用于展示后台任务的执行时长。

9、总结

通过上述封装的函数,我们可以方便地将毫秒数转换为易于展示的时长格式,支持时、分、秒显示,并考虑了输入校验和性能优化。无论是短时任务还是长时间运行的计时功能,都可以通过这种方式来呈现直观的时间信息。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小茗同学阿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值