是否有一种方法将前导零前置到数字,从而产生固定长度的字符串?例如,如果我指定2个位置,5就变成了“05”。
注意:可能过时了。ECMAScript 2017包含String.prototype.padStart。
您必须将数字转换为字符串,因为数字前导为零是没有意义的。就像这样:
function pad(num, size) {
num = num.toString();
while (num.length < size) num = "0" + num;
return num;
}
或者,如果你知道你永远不会使用超过X个0,这可能会更好。这里假设您永远不需要超过10个数字。
function pad(num, size) {
var s = "000000000" + num;
return s.substr(s.length-size);
}
如果你关心负数,你就得把它剥下来读一读。
更新:使用ES2017 String.prototype.padStart方法的小一行函数:
const zeroPad = (num, places) => String(num).padStart(places, '0') console.log(zeroPad(5, 2));"05" console.log(zeroPad(5, 4));"0005" console.log(zeroPad(5, 6));"000005" console.log(zeroPad(1234, 2));"1234"
另一种ES5方法:
function zeroPad(num, places) {
var zero = places - num.toString().length + 1;
return Array(+(zero > 0 && zero)).join("0") + num;
}
zeroPad(5, 2); // "05"
zeroPad(5, 4); // "0005"
zeroPad(5, 6); // "000005"
zeroPad(1234, 2); // "1234" :)
只是为了好玩(我有一些时间可以消磨),一个更复杂的实现可以缓存0字符串:
pad.zeros = new Array(5).join('0');
function pad(num, len) {
var str = String(num),
diff = len - str.length;
if(diff <= 0) return str;
if(diff > pad.zeros.length)
pad.zeros = new Array(diff + 1).join('0');
return pad.zeros.substr(0, diff) + str;
}
如果填充计数很大,并且函数被频繁调用,它实际上比其他方法更好…
从https://gist.github.com/1180489
function pad(a, b){
return(1e15 + a + '').slice(-b);
}
评论:
function pad(
a, // the number to convert
b // number of resulting characters
){
return (
1e15 + a + // combine with large number
"" // convert to string
).slice(-b) // cut leading "1"
}
你可以扩展Number对象:
Number.prototype.pad = function(size) {
var s = String(this);
while (s.length < (size || 2)) {s = "0" + s;}
return s;
}
例子:
(9).pad(); //returns "09"
(7).pad(3); //returns "007"
推荐文章
- 如何使用Jest测试对象键和值是否相等?
- 将长模板文字行换行为多行,而无需在字符串中创建新行
- 如何在JavaScript中映射/减少/过滤一个集?
- Bower: ENOGIT Git未安装或不在PATH中
- 添加javascript选项选择
- 在Node.js中克隆对象
- 为什么在JavaScript的Date构造函数中month参数的范围从0到11 ?
- 使用JavaScript更改URL参数并指定默认值
- 在window.setTimeout()发生之前取消/终止
- 如何删除未定义和空值从一个对象使用lodash?
- 检测当用户滚动到底部的div与jQuery
- 在JavaScript中检查字符串包含另一个子字符串的最快方法?
- 检测视口方向,如果方向是纵向显示警告消息通知用户的指示
- ASP。NET MVC 3 Razor:在head标签中包含JavaScript文件
- 禁用从HTML页面中拖动图像