当我测试一个检查数字有效性的函数时,我注意到一些非常奇怪的东西,我在测试'number.toString()[0]时首先注意到它。如果我控制台登录(fLetter(019272)); '0'始终显示'1' 在线检查后,我找不到与在包含'0'的数字上使用toString()方法相关的任何问题。
function numberValidate(number) {
var numCheck = [0, 5, 7, 8, 9];
var fLetter = number.toString()[0];
if (number.match(/^\d{6}$/)) {
for (var i = 0; i < 5; i++) {
if (fLetter == numCheck[i]) {
return false;
} else {
return true;
}
}
}
}
我尝试使用和不使用toString()方法检查一些其他测试变量,并得到一些我无法理解的结果。 **注意 - toString()添加产生相同的结果(在JSfiddle中执行)
var numTest = 00000000;
var numTest1 = 20203020;
var numTest2 = 011000110100;
var numTest3 = 01928;
var numTest4 = 012345;
console.log(numTest); //Returned 0
console.log(numTest1); //Returned 20203020
console.log(numTest2); //Returned 1207996480
console.log(numTest3); //Returned 1928
console.log(numTest4); //Returned Returned 5349
任何人都可以了解为什么我会获得这些值吗?感谢
答案 0 :(得分:4)
010被视为八进制表示法,并且0x10将被视为十六进制表示法。八进制数字系统使用数字0到7.因此,019给出19,因为9不是八进制数字。这里有一些十进制数字及其八进制表示法:
1 1 | 5 5 | 9 11 | 13 15
2 2 | 6 6 | 10 12 | 14 16
3 3 | 7 7 | 11 13 | 15 17
4 4 | 8 10 | 12 14 | 16 20
如您所见,由于我们只有8位数字(0,1,2,3,4,5,6,7),8变为10,16(8 + 8)变为20(10 + 10) 。为了使事情更加清晰,让我们看看如何计算10位数(像往常一样),然后用8位数。
使用10位数字:
0, 1, 2, 3, 4, 5, 6, 7, 8, 9, no more digits
nevermind, add 1 to the tenths and restart from 0
10, 11, 12, 13, 14, 15, 16, 17, 18, 19, no more digits
nevermind, add 1 to the tenths and restart from 0
20, 21, etc...
使用8位数字:
0, 1, 2, 3, 4, 5, 6, 7, no more digits
nevermind, add 1 to the "tenths" and restart from 0
10, 11, 12, 13, 14, 15, 16, 17, no more digits
nevermind, add 1 to the "tenths" and restart from 0
20, 21, etc...
这同样适用于二进制数:
0, 1, no more digits
10, 11, no more digits
100, 101, no more digits
110, 111, no more digits
1000, etc...
让我们与十进制表示法进行比较:
1 1 | 5 101 | 9 1001
2 10 | 6 110 | 10 1010
3 11 | 7 111
4 100 | 8 1000
答案 1 :(得分:0)
Number是数字的64位浮点表示。它不会将数字保存为字符数组,因此前导零不可用。 String保存一个字符数组,因此前导0不会丢失
如果可能,JavaScript允许透明类型转换,因此字符串“0111”==到数字111.因此,如果您编写代码"0111" == 111
,它将返回true。
Javascript提供了两个相等运算符==和严格相等===第二个要求双方都是相同类型,因此Number(111) === String("111")
将返回false,因为它们不是同一类型。这同样适用于不等式运算符!= and !==