是否有一种方法将前导零前置到数字,从而产生固定长度的字符串?例如,如果我指定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"
推荐文章
- 检测用户何时离开网页的最佳方法?
- 当“模糊”事件发生时,我如何才能找到哪个元素的焦点去了*到*?
- React不会加载本地图像
- 如何将Blob转换为JavaScript文件
- 在另一个js文件中调用JavaScript函数
- 如何在svg元素中使用z索引?
- 如何求一个数的长度?
- 跨源请求头(CORS)与PHP头
- 如何用Express/Node以编程方式发送404响应?
- parseInt(null, 24) === 23…等等,什么?
- JavaScript变量声明在循环外还是循环内?
- 元素在“for(…in…)”循环中排序
- 在哪里放置JavaScript在HTML文件?
- 什么时候.then(success, fail)被认为是承诺的反模式?
- 从浏览器下载JSON对象作为文件