1.整数和浮点数
JavaScript 内部,所有数字都是以64位浮点数形式储存,即使整数也是如此。所以,1
与1.0
是相同的,是同一个数。
这就是说,JavaScript 语言的底层根本没有整数,所有数字都是小数(64位浮点数)
》第1位:符号位,0表示正数,1表示负数
》第2位到第12位:指数部分
》第13位到第64位:小数部分(即有效数字)
由于浮点数不是精确的值,所以涉及小数的比较和运算要特别小心。如:
0.3/0.1
2.9999999999999996
(0.3 - 0.2) === (0.2 - 0.1)
false
(0.1+0.2)==0.3
false
javaScript 能够表示的数值范围为21024到2-1023(开区间),超出这个范围的数无法表示
2.数值表示法
以下两种情况,JavaScript 会自动将数值转为科学计数法表示,其他情况都采用字面形式直接表示:
(1)小数点前的数字多于21位。
(2)小数点后的零多于5个。
3.数值的进制
》十进制:没有前导0的数值。
》八进制:有前缀0o或0O的数值,或者有前导0、且只用到0-7的八个阿拉伯数字的数值。
》十六进制:有前缀0x或0X的数值。
》二进制:有前缀0b或0B的数值。
4.特殊数值
(1)+0 -0
几乎所有场合,正零和负零都会被当作正常的0
。唯一有区别的场合是,+0
或-0
当作分母,返回的值是不相等的
之所以出现这样结果,是因为除以正零得到+Infinity
,除以负零得到-Infinity
,这两者是不相等的
(2)NaN
(3)Infinity
5.与数值相关的全局方法
(1)parseInt();
转换规则:
1.如果parseInt
的参数不是字符串,则会先转为字符串再转换。
2.字符串转为整数的时候,是一个个字符依次转换,如果遇到不能转为数字的字符,就不再进行下去,返回已经转好的部分。
3.如果字符串的第一个字符不能转化为数字(后面跟着数字的正负号除外),返回NaN
。
4.parseInt
的返回值只有两种可能,不是一个十进制整数,就是NaN
。
5.该方法还可以接受第二个参数(2到36之间),表示被解析的值的进制,返回该值对应的十进制数。默认情况下,parseInt
的第二个参数为10,即默认是十进制转十进制
6.如果字符串包含对于指定进制无意义的字符,则从最高位开始,只返回可以转换的数值。如果最高位无法转换,则直接返回NaN
实验及返回结果如下:
parseInt('+1');
1
parseInt('0x10')
16
parseInt('011')
11
parseInt(1000000000000000000000.5)
1
parseInt(1000000000000000000000)
1
parseInt('1000000000000000000000');
1e+21
parseInt(0.0000008)
8
parseInt('8e-7')
8
parseInt('0.0000008');
0
parseInt('1000');
1000
parseInt('1000',2);
8
parseInt('1000',8);
512
parseInt('1000',16);
4096
parseInt('550',2);
NaN
parseInt('150',2);
1
parseInt(011, 2)
NaN
parseInt(String(011), 2)
NaN
parseInt('011', 2)
3
(1)parseFloat();
转换规则:
1.如果字符串符合科学计数法,则会进行相应的转换。
2.如果字符串包含不能转为浮点数的字符,则不再进行往后转换,返回已经转好的部分。
3.该方法会自动过滤字符串前导的空格。
4.如果参数不是字符串,或者字符串的第一个字符不能转化为浮点数,则返回NaN
。
5.parseFloat
会将空字符串转为NaN
实验及返回结果如下:
parseFloat('3.14');
3.14
parseFloat('314E-2');
3.14
parseFloat('0.0314e+2');
3.14
parseFloat('3.14MORE56');
3.14
parseFloat(' 3.14 ');
3.14
该博文学习自阮一峰的《JavaScript 标准参考教程(alpha)》