JavaScript Number 对象
本文最后更新于:2024年3月18日 凌晨
JavaScript Number 对象
- JavaScript 只有一种数字类型。
- JavaScript 数字可以使用也可以不使用小数点来书写:
1 2
| var y=123e5; var z=123e-5;
|
所有 JavaScript 数字均为 64 位
- JavaScript 不是类型语言,与许多其他编程语言不同,JavaScript 不定义不同类型的数字,比如整数,短,长,浮点等等。
- 在JavaScript中,数字不分为整数类型和浮点型类型,所有的数字都是由浮点型类型,JavaScript 采用 IEEE754 标准定义的 64 位浮点格式表示数字,它能表示最大值为 ±1.7976931348623157e+308,最小值为 ±5e-324
值(aka Fraction/Mantissa) |
指数 |
Sign |
52 bits (0 - 51) |
11 bits (50 - 62) |
1 bit (63) |
精度
- 整数(不使用小数点或指数计数法)最多为 15 位。
1 2
| var x = 999999999999999; var y = 9999999999999999;
|
- 小数的最大位数是 17,但是浮点运算并不总是 100% 准确:
八进制和十六进制
- 如果前缀为 0,则 JavaScript 会把数值常量解释为八进制数,如果前缀为 0 和 “x”,则解释为十六进制数。
1 2
| var y = 0377; var z = 0xFF;
|
- 默认情况下,JavaScript 数字为十进制显示。
- 但是你可以使用
toString()
方法输出16进制,8进制,2进制。
1 2 3 4
| var myNumber=128; myNumber.toString(16); myNumber.toString(8); myNumber.toString(2);
|
无穷大(Infinity)
- 当数字运算结果超过了JavaScript所能表示的数字上限(溢出),结果为一个特殊的无穷大(infinity)值,在JavaScript中以Infinity表示,同样地,当负数的值超过了JavaScript所能表示的负数范围,结果为负无穷大,在JavaScript中以-Infinity表示,无穷大值的行为特性和我们所期望的是一致的:基于它们的加,减,乘和除运算结果还是无穷大(当然还保留它们的正负号)
1 2 3 4 5
| myNumber=2; while (myNumber!=Infinity) { myNumber=myNumber*myNumber; }
|
1 2
| var x = 2/0; var y = -2/0;
|
NaN - 非数字值
- NaN 属性是代表非数字值的特殊值,该属性用于指示某个值不是数字,可以把 Number 对象设置为该值,来指示其不是数字值。
- 你可以使用
isNaN()
全局函数来判断一个值是否是 NaN 值。
1 2 3 4
| var x = 1000 / "Apple"; isNaN(x); var y = 100 / "1000"; isNaN(y);
|
1 2
| var x = 1000 / 0; isNaN(x);
|
数字可以是数字或者对象
- 数字可以私有数据进行初始化,就像 x = 123;
- JavaScript 数字对象初始化数据,
var y = new Number(123);
1 2 3 4
| var x = 123; var y = new Number(123); typeof(x) typeof(y)
|
Number 属性
属性 |
描述 |
Number.MAX_VALUE |
最大值 |
Number.MIN_VALUE |
最小值 |
Number.NaN |
非数字 |
Number.NEGATIVE_INFINITY |
负无穷,在溢出时返回 |
Number.POSITIVE_INFINITY |
正无穷,在溢出时返回 |
Number.EPSILON |
表示 1 和比最接近 1 且大于 1 的最小 Number 之间的差别 |
Number.MIN_SAFE_INTEGER |
最小安全整数, |
Number.MAX_SAFE_INTEGER |
最大安全整数, |
数字方法
数字类型原型上的一些方法
方法 |
描述 |
toExponential() |
返回一个数字的指数形式的字符串,如:1.23e+2 |
toFixed() |
返回指定小数位数的表示形式,
var a=123;
b=a.toFixed(2); // b="123.00" |
toPrecision() |
返回一个指定精度的数字,如下例子中,a=123 中,3会由于精度限制消失:
var a=123;
b=a.toPrecision(2); // b="1.2e+2" |