在许多开发场景中,后端接口返回的数据常常是以毫秒为单位的时间戳或持续时长。而在前端展示时,我们通常需要将这些毫秒数转换成更易读的时长格式,通常采用“时:分:秒”的形式(例如 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、代码解析
将毫秒转换为秒数:
parseint(milliseconds / 1000)
:将毫秒转换为秒,parseint
用于去除小数部分。
计算小时、分钟和秒数:
- 使用整除 (
/
) 和取余 (%
) 运算符将总秒数转换为小时、分钟和秒数。 - 例如,1 小时 = 3600 秒,1 分钟 = 60 秒。
格式化输出:
- 通过条件判断来判断小时、分钟、秒数是否小于 10,如果小于 10,则在前面补充零。
- 最终输出格式为
hh:mm:ss
。
4、优化与增强
更精确的参数处理
当前函数处理了小时、分钟和秒数的基本逻辑,但它在输入非常小(例如几秒钟)或非常大的毫秒数时可能会出现一些不必要的行为。为了确保它对极限情况的处理更加鲁棒,我们可以增强函数的稳定性:
- 避免负数:如果传入的毫秒数为负值,应该返回一个默认的“00:00:00”。
- 避免无效的输入:可以对非数字类型的输入进行校验。
提高代码的可读性和简洁性
我们可以使用 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、改进说明
math.floor()
:替换 parseint
,确保四舍五入问题不再出现。
padstart()
:用 padstart(2, '0')
方法来简化补零的代码,避免手动拼接。
输入验证:添加了输入校验,确保只有非负数的有效数字能够参与计算。若输入无效(如负数或非数字),则返回 "00:00:00"。
7、性能优化
对于非常大的毫秒数,尽管该函数已经进行了一些基础优化,但对于需要处理大量数据或长时间运行的应用(例如计时器或统计时长的应用),我们仍然需要考虑性能:
- 避免不必要的计算:如果传入的毫秒数非常大,可能涉及多个小时以上,仍然可以使用简单的算数运算,不需要过多的逻辑判断。
- 缓存结果:如果在应用中频繁调用该函数,可以考虑缓存转换结果,避免重复计算。
8、应用场景
该毫秒转换函数适用于多个场景:
- 计时器:如在线竞赛、倒计时器。
- 视频时长:如播放视频时显示已播放时长。
- 任务时长统计:用于展示后台任务的执行时长。
9、总结
通过上述封装的函数,我们可以方便地将毫秒数转换为易于展示的时长格式,支持时、分、秒显示,并考虑了输入校验和性能优化。无论是短时任务还是长时间运行的计时功能,都可以通过这种方式来呈现直观的时间信息。
到此这篇关于javascript实现将毫秒数转换为易读时长格式的文章就介绍到这了,更多相关javascript毫秒数格式转换内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
发表评论