前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >JavaScript补齐指定位数

JavaScript补齐指定位数

作者头像
奋飛
发布2019-08-15 09:51:34
6410
发布2019-08-15 09:51:34
举报
文章被收录于专栏:Super 前端Super 前端

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

一、通常解决方案

代码语言:javascript
复制
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去判断,不够灵活,扩展性较差。

二、可扩充的解决方案

代码语言:javascript
复制
/**
 * 可扩充的解决方案
 * @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”

代码语言:javascript
复制
dataLeftCompleting(4, "0", 1);  // 要求4位,使用“0”补齐

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

代码语言:javascript
复制
dataLeftCompleting(4, "*", 1);  // 要求4位,使用“*”补齐

三、JavaScript稀疏数组

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

代码语言:javascript
复制
Array(3).map(function(){
    return "0";
});     //[undefined, undefined, undefined]

注意和上示例区别

代码语言:javascript
复制
Array.apply(null, Array(3)).map(function(){
    return "0";
});     //["0", "0", "0"]
对比
对比
代码语言:javascript
复制
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()方法:

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

更为简单的padStart()方法:

代码语言:javascript
复制
"1".padStart(3, "0");   // 001
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2016年08月05日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、通常解决方案
  • 二、可扩充的解决方案
  • 三、JavaScript稀疏数组
  • 四、ES6提供的方法
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档