JavaScript补齐指定位数

本文介绍了一种灵活的日期格式化方法,通过自定义补全字符和位数来满足不同的显示需求,同时探讨了JavaScript稀疏数组及ES6新特性在该场景的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

开发过程中,我们会经常遇到日期或者数值显示指定位数,例如: “2016-8-3”显示为”2016-08-03”

一、通常解决方案

function dataLeftCompleting(value){
    return parseInt(value) < 10 ? "0" + value : value;
}
// 测试
var originValue = "2016-8-3",
    originDate = new Date(originValue);
var formatValue = originDate.getFullYear() 
        + "-" + dataLeftCompleting(originDate.getMonth() + 1) 
        + "-" + dataLeftCompleting(originDate.getDate());   // "2016-08-03"

上述补齐方式严格依据当前数值是否小于10去判断,不够灵活,扩展性较差。

二、可扩充的解决方案

/**
 * 可扩充的解决方案
 * @param bits 格式化位数
 * @param identifier 补全字符
 * @param value 值
 */
function dataLeftCompleting(bits, identifier, value){
    value = Array(bits + 1).join(identifier) + value;
    return value.slice(-bits);
}
// 测试
var originValue = "2016-8-3",
    originDate = new Date(originValue);
var formatValue = originDate.getFullYear() 
        + "-" + dataLeftCompleting(2, "0", originDate.getMonth() + 1) 
        + "-" + dataLeftCompleting(2, "0", originDate.getDate());   // "2016-08-03"

上述看似和“通常解决方案”没有啥差异,但是其灵活度却增大了很多!!

示例1:”1”格式化为”0001”

dataLeftCompleting(4, "0", 1);  // 要求4位,使用“0”补齐

示例2:”1”格式化为”***1”

dataLeftCompleting(4, "*", 1);  // 要求4位,使用“*”补齐

三、JavaScript稀疏数组

稀疏数组就是包含从0开始的不连续索引的数组。
上述示例中在使用“补全字符”填充数组时,并没有使用稀疏数组去实现:JavaScript循环迭代数组,会跳过这些“稀疏”值!

Array(3).map(function(){
    return "0";
});     //[undefined, undefined, undefined]

注意和上示例区别

Array.apply(null, Array(3)).map(function(){
    return "0";
});     //["0", "0", "0"]

对比

1 in [0,,2]         ==> false
1 in [0,,]          ==> false
1 in [,,2]          ==> false
1 in [,,]           ==> false
1 in [,undefined,]  ==> true
1 in Array.apply(null, Array(3))    ==> true

四、ES6提供的方法

repeat()方法:

/**
* 可扩充的解决方案
* @param bits 格式化位数
* @param identifier 补全字符
* @param value 值
*/
function dataLeftCompleting(bits, identifier, value){
   value = identifier.repeat(bits) + value;
   return value.slice(-bits);
}

更为简单的padStart()方法:

"1".padStart(3, "0");   // 001
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

奋飛

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

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

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

打赏作者

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

抵扣说明:

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

余额充值