数值

1.整数和浮点数

JavaScript 内部,所有数字都是以64位浮点数形式储存,即使整数也是如此。所以,11.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)》

原文地址:https://www.cnblogs.com/zjy1017/p/7648057.html