我有一个小于100的整数,并使用JavaScript打印到HTML页面。如何格式化整数,使其长度恰好是两位数?例如:
01
02
03
...
09
10个
11个
12个
......
答案 0 :(得分:34)
function pad(d) {
return (d < 10) ? '0' + d.toString() : d.toString();
}
pad(1); // 01
pad(9); // 09
pad(10); // 10
答案 1 :(得分:22)
String("0" + x).slice(-2);
其中x
是您的号码。
答案 2 :(得分:8)
只需使用以下短函数即可获得所需的结果:
function pad2(number) {
return (number < 10 ? '0' : '') + number
}
答案 3 :(得分:4)
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/padStart
String(number).padStart(2, '0')
答案 4 :(得分:3)
在Javascript中向左侧填充数字的直接方法是按日志基数10计算位数。 例如:
function padLeft(positiveInteger, totalDigits) {
var padding = "00000000000000";
var rounding = 1.000000000001;
var currentDigits = positiveInteger > 0 ? 1 + Math.floor(rounding * (Math.log(positiveInteger) / Math.LN10)) : 1;
return (padding + positiveInteger).substr(padding.length - (totalDigits - currentDigits));
}
舍入因子修复了无法获得10的精确日志的问题,例如Math.log(1000)/ Math.LN10 == 2.9999999999999996 当然应该添加参数验证。
答案 5 :(得分:2)
// Return a string padded
function FormatMe(n) {
return (n<10) ? '0'+n : n;
}
答案 6 :(得分:2)
function padLeft(a, b) {
var l = (a + '').length;
if (l >= b) {
return a + '';
} else {
var arr = [];
for (var i = 0; i < b - l ;i++) {
arr.push('0');
}
arr.push(a);
return arr.join('');
}
}
答案 7 :(得分:0)
const str = '12:5'
输出:12:05
答案 8 :(得分:0)
我通常使用此功能。
function pad(n, len) {
let l = Math.floor(len)
let sn = '' + n
let snl = sn.length
if(snl >= l) return sn
return '0'.repeat(l - snl) + sn
}
使用示例
pad(1, 1) // ==> returns '1' (string type)
pad(384, 5) // ==> returns '00384'
pad(384, 4.5)// ==> returns '0384'
pad(5555, 2) // ==> returns '5555'
答案 9 :(得分:0)
先前答案的改进版本:
var result = [...Array(12)].map((_, i) => zeroFill(i + 1, 2));
function zeroFill(num, size) {
let s = num + '';
while (s.length < size) s = `0${s}`;
return s;
}
console.log(result)