JavaScript 数值
JavaScript 只有一种数值类型。书写数值时带不带小数点均可。
超大或超小的数可通过科学计数法来写:
JavaScript 数值始终是 64 位的浮点数
与许多其他编程语言不同,JavaScript 不会定义不同类型的数,比如整数、短的、长的、浮点的等等。
JavaScript 数值始终以双精度浮点数来存储,根据国际 IEEE 754 标准。
此格式用 64 位存储数值,其中 0 到 51 存储数字(片段),52 到 62 存储指数,63 位存储符号:
值(aka Fraction/Mantissa) | 指数 | 符号 |
---|---|---|
52 bits (0 - 51) | 11 bits (52 - 62) | 1 bit (63) |
精度
整数(不使用指数或科学计数法)会被精确到 15 位。
实例
var y = 9999999999999999; // y 将是 10000000000000000
小数的最大数是 17 位,但是浮点的算数并不总是 100% 精准:
使用乘除法有助于解决上面的问题:
数字和字符串相加
警告!!
JavaScript 的加法和级联(concatenation)都使用 + 运算符。
数字用加法。字符串用级联。
如果您对两个数相加,结果将是一个数:
如果对两个字符串相加,结果将是一个字符串的级联:
如果您对一个数和一个字符串相加,结果也是字符串级联:
如果您对一个字符串和一个数字相加,结果也是字符串级联:
常见的错误是认为结果应该是 30:
常见的错误是认为结果应该是 102030:
JavaScript 从左向右进行编译。
因为 x 和 y 都是数,10 + 20 将被相加。
因为 z 是字符串,30 + "30" 被级联。
数字字符串
JavaScript 字符串可以拥有数字内容:
var y = "100"; // y 是一个字符串
在所有数字运算中,JavaScript 会尝试将字符串转换为数字:
该例如此运行:
var y = "10";
var z = x / y; // z 将是 10
该例也将如此运行:
var y = "10";
var z = x * y; // z 将是 1000
该例如此运行:
var y = "10";
var z = x - y; // z 将是 90
但是该例不会如上例般运行:
var y = "10";
var z = x + y; // z 不会是 110(它将是 10010)
在最后一个例子中,JavaScript 用 + 运算符对字符串进行了级联。
NaN - 非数值
NaN 属于 JavaScript 保留词,指示某个数不是合法数。
尝试用一个非数字字符串进行除法会得到 NaN
(非数字):
不过,假如字符串包含数值,则结果将是数:
您可使用全局 JavaScript 函数 isNaN() 来确定某个值是否是数:
要小心 NaN。假如您在数学运算中使用了 NaN,则结果也将是 NaN:
结果也许是串连接:
NaN 是数,typeof NaN 返回 number:
Infinity
Infinity (或 -Infinity)是 JavaScript 在计算数时超出最大可能数范围时返回的值。
实例
while (myNumber != Infinity) { // 执行到无穷大
myNumber = myNumber * myNumber;
}
除以 0(零)也会生成 Infinity:
Infinity 是数:typeOf Infinity 返回 number。
十六进制
JavaScript 会把前缀为 0x 的数值常量解释为十六进制。
绝不要用前导零写数字(比如 07)。
一些 JavaScript 版本会把带有前导零的数解释为八进制。
默认地,Javascript 把数显示为十进制小数。
但是您能够使用 toString() 方法把数输出为十六进制、八进制或二进制。
十六进制以16为基数。十进制以10为基数。八进制是基数8。二进制是基数2。
实例
myNumber.toString(10); // 返回 32
myNumber.toString(32); // 返回 10
myNumber.toString(16); // 返回 20
myNumber.toString(8); // 返回 40
myNumber.toString(2); // 返回 100000
数值可以是对象
通常 JavaScript 数值是通过字面量创建的原始值:var x = 123;
但是也可以通过关键词 new 定义为对象:var y = new Number(123);
请不要创建数值对象。这样会拖慢执行速度。
new 关键词使代码复杂化,并产生某些无法预料的结果:
当使用 == 相等运算符时,相等的数看上去相等:
当使用 === 相等运算符后,相等的数变为不相等,因为 === 运算符需要类型和值同时相等。
甚至更糟。对象无法进行对比:
注意 (x==y)
和 (x===y)
之间的差异。
比较两个 JavaScript 对象将始终返回 false
。