JavaScript 隻有一種數字類型。
可以使用也可以不使用小數點來書寫數字。
JavaScript 數字可以使用也可以不使用小數點來書寫:
var
pi=3.14; // 使用小數點
x=34; // 不使用小數點
極大或極小的數字可通過科學(指數)計數法來寫:
var y=123e5; // 12300000
var z=123e-5; // 0.00123
JavaScript 不是類型語言。與許多其他程式設計語言不同,JavaScript 不定義不同類型的數字,比如整數、短、長、浮點等等。
在JavaScript中,數字不分為整數類型和浮點型類型,所有的數字都是由
浮點型類型。JavaScript 采用 IEEE754 标準定義的 64 位浮點格式表示數字,它能表示最大值(Number.MAX_VALUE)為 ±1.7976931348623157e+308,最小值(Number.MIN_VALUE)為 ±5e-324。
此格式用 64 位存儲數值,其中 0 到 51 存儲數字(片段),52 到 62 存儲指數,63 位存儲符号:

值 (aka Fraction/Mantissa)
指數(Exponent)
符号(Sign)
52 bits (0 - 51)
11 bits (52 - 62)
1 bit (63)
整數(不使用小數點或指數計數法)最多為 15 位。
var x = 999999999999999; // x 為 999999999999999
var y = 9999999999999999; // y 為 10000000000000000
小數的最大位數是 17,但是浮點運算并不總是 100% 準确:
var x = 0.2+0.1; // 輸出結果為 0.30000000000000004
如果字首為 0,則 JavaScript 會把數值常量解釋為八進制數,如果字首為 0 和 "x",則解釋為十六進制數。
var y = 0377;
var z = 0xFF;
絕不要在數字前面寫零,除非您需要進行八進制轉換。
預設情況下,JavaScript 數字為十進制顯示。
但是你可以使用 toString() 方法 輸出16進制、8進制、2進制。
var myNumber=128;
myNumber.toString(16); // 傳回 80
myNumber.toString(8); // 傳回 200
myNumber.toString(2); // 傳回 10000000
當數字運算結果超過了JavaScript所能表示的數字上限(溢出),結果為一個特殊的無窮大(infinity)值,在JavaScript中以Infinity表示。同樣地,當負數的值超過了JavaScript所能表示的負數範圍,結果為負無窮大,在JavaScript中以-Infinity表示。無窮大值的行為特性和我們所期望的是一緻的:基于它們的加、減、乘和除運算結果還是無窮大(當然還保留它們的正負号)。
myNumber=2;
while (myNumber!=Infinity)
{
myNumber=myNumber*myNumber; // 重複計算直到 myNumber 等于 Infinity
}
除以0也産生了無限:
var x = 2/0;
var y = -2/0;
NaN 屬性是代表非數字值的特殊值。該屬性用于訓示某個值不是數字。可以把 Number 對象設定為該值,來訓示其不是數字值。
你可以使用 isNaN() 全局函數來判斷一個值是否是 NaN 值。
var x = 1000 / "Apple";
isNaN(x); // 傳回 true
var y = 100 /
"1000";
isNaN(y); // 傳回 false
除以0是無窮大,無窮大是一個數字:
var x = 1000 / 0;
isNaN(x); // 傳回 false
數字可以私有資料進行初始化,就像
x = 123;
JavaScript 數字對象初始化資料, var y = new
Number(123);
var x = 123;
var y = new Number(123);
typeof(x) // 傳回 Number
typeof(y) // 傳回 Object
var x = 123;
(x === y) // 為 false,因為 x 是一個數字,y 是一個對象
屬性
描述
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
最大安全整數。
方法
Number.parseFloat()
将字元串轉換成浮點數,和全局方法 parseFloat() 作用一緻。
Number.parseInt()
将字元串轉換成整型數字,和全局方法 parseInt() 作用一緻。
Number.isFinite()
判斷傳遞的參數是否為有限數字。
Number.isInteger()
判斷傳遞的參數是否為整數。
Number.isNaN()
判斷傳遞的參數是否為 isNaN()。
Number.isSafeInteger()
判斷傳遞的參數是否為安全整數。
toExponential()
傳回一個數字的指數形式的字元串,如:1.23e+2
toFixed()
傳回指定小數位數的表示形式。
toPrecision()
傳回一個指定精度的數字。如下例子中,a=123 中,3會由于精度限制消失: