Number類型
Number類型應該是ECMAScript中最令人關注的數據類型了,這種類型使用IEEE754格式來表示整數和浮點數值(浮點數值在某些語言中也被稱為雙精度數值)。為支持各種數值類型,ECMA-262定義了不同的數值字面量格式。
最基本的數值字面量格式是十進制整數,十進制整數可以像下面這樣直接在代碼中輸入:
var intNum=55; //整數
除了以十進制表示外,整數還可以通過八進制(以8為基數)或十六進制(以16為基數)的字面值來表示。其中,八進制字面值的第一位必須是零(0),然后是八進制數字序列(0~7)。如果字面值中的數值超出了范圍,那么前導零將被忽略,后面的數值將被當作十進制數值解析。請看下面的例子:
var octalNuml=070; //八進制的56
var octalNum2=079; //無效的八進制數值——解析為79
var octalNum3=08; ,/無效的八進制數值——解析為8
十六進制字面值的前兩位必須是Ox,后跟任何十六進制數字(O~9及A~F)。其中,字母A~F可以大寫,也可以小寫。如下面的例子所示:
var hexNuml=OxA; //十六進制的10
var hexNum2=Oxlf; //十六進制的31
南昌網絡公司百恒網絡前端開發工程師提醒企業網站建設技術人員,雖然數值可以用八進制或十六進制來表示,但在進行算術計算時,所有以八進制和十六進制表示的數值最終都將被轉換成十進制數值。
1.浮點數值
所謂浮點數值,就是該數值中必須包含一個小數點,并且小數點后面必須至少有一位數字。雖然小數點前面可以沒有整數,但我們不推薦這種寫法。以下是浮點數值的幾個例子:
var floatNuml=1.1;
var floatNum2=O.l;
var floatNum3=.1; //有效,但不推薦
南昌網站優化公司百恒網絡前端開發工程師提醒技術人員由于保存浮點數值需要的內存空間是保存整數值的兩倍,因此ECMAScript會不失時機地將浮點數值轉換為整數值。顯然,如果小數點后面沒有跟任何數字,那么這個數值就可以作為整數值來保存。同樣地,如果浮點數值本身表示的就是一個整數(如1.0),那么該值也會被轉換為整數,如下面的例子所示:
var floatNuml=1.; //小數點后面沒有數字——解析為l
var floatNum2=10.0; //整數——解析為10
對于那些極大或極小的數值,可以用e表示法(即科學計數法)表示的浮點數值表示。用e表示法表示的數值等于e前面的數值乘以10的指數次冪。ECMAScript中e表示法的格式也是如此,即前面是一命數值(可以是整數也可以是浮點數),中間是一個大寫或小寫的字母E,后面是10的冪中的指數,該冪值將用來與前面的數相乘。下面是一個使用e表示法表示數值的例子:
var floatNum=3.125e7; //等于31250000
在這個例子中,使用e表示法表示的變量floatNum的形式雖然簡潔,但它的實際值則是31250000。在此,e表示法的實際含義就是“3.125乘以l07'’。
也可以使用e表示法表示極小的數值,如0.00000000000000003,這個數值可以使用更簡潔的3e-17表示。在默認情況下,ECMASctipt會將那些小數點后面帶有6個零以上的浮點數值轉換為以e表示法表示的數值(例如,0.0000003會被轉換成3e-7)。
浮點數值的最高精度是17位小數,但在進行算術計算時其精確度遠遠不如整數。例如,0.1加0.2的結果不是0.3,而是0.30000000000000004。這個小小的舍入誤差會導致無法測試特定的浮點數值。例如:
if(a+b==0.3){//不要做這樣的測試!
alert("You got 0.3.”);
}
南昌做網站公司百恒網絡前端開發工程師總結:在這個例子中,我們測試的是兩個數的和是不是等于0.3。如果達兩個數是0.05和0.25,或者是0.15和0.15都不會有問題。而如前所述,如果這兩個數是0.1和0.2,那么測試將無法通過。因此,永遠不要測試某個特定的浮點數值。
關于浮點數值計算會產生舍入誤差的問題,有一點需要明確:這是使用基于IEEE754數值的浮點計算的通病,ECMAScript并非獨此一家;其他使用相同數值格式的語言也存在這個問題。
2.數值范圍
由于內存的限制,ECMAScript并不能保存世界上所有的數值。ECMAScript能夠表示的最小數值保存在Number.MIN VALUE中——在大多數瀏覽器中,這個值是Se-324;能夠表示的最大數值保存在Number.MAX VALUE中——在大多數瀏覽器中,這個值是1.7976931348623157e+308。如果某次計算的結果得到了一個超出JavaScript數值范圍的值,那么這個數值將被自動轉換成特殊的工nflnity值。
具體來說,如果這個數值是負數,則會被轉換成一工nfinity(負無窮),如果這個數值是正數,則會被轉換成Infinity(正無窮)。
如上所述,如果某次計算返回了正或負的工nfinity值,那么該值將無法繼續參與下一次的計算,因為工nfinity不是能夠參與計算的數值。要想確定一個數值是不是有窮的(換句話說,是不是位于 最小和最大的數值之間),可以使用isFinite()函數。這個函數在參數位于最小與最大數值之間時會返回true,如下面的例子所示:
var result=Number.MAX_VALUE+Number.MAX_VALUE;
alert (isFinite (result))j //false
盡管在計算中很少出現某些值超出表示范圍的情況,但在執行極小或極大數值的計算時,檢測監控這些值是可能的,也是必需的。
3.NaN
NaN,即非數值(Nota Number)是一個特殊的數值,這個數值用于表示一個本來要返回數值的操作數未返回數值的情況(這樣就不會拋出錯誤了)。例如,在其他編程語言中,任何教值除以o都會導致錯誤,從而停止代碼執行。但在ECMAScript中,任何數值除以0會返回NaN,因此不會影響其他代碼的執行。
NaN本身有兩個非同尋常的特點。首先,任何涉及NaIV的操作(例如NaN/10)都會返回NaN,這個特點在多步計算中有可能導致問題。其次,NaN與任何值都不相等,包括NaN本身。例如,下面的代碼會返回false:
alert (NaN==NaN)j //false
針對NaN的這兩個特點,ECMAScript定義了isN型壘函數。這個函數接受一個參數,該參數可以是任何類型,而函數會幫我們確定這個參數是否“不是數值”。isNaN()在接收到一個值之后,會嘗試將這個值轉換為數值。某些不是數值的值會直接轉換為數值,例如字符串”10?;駼oolean值。而任何不能被轉換為數值的值都會導致這個函數返回true。請看下面的例子:
alert (isNaN (NaN))j //true
alert(isNaN(10))j //false(10是一個數值)
alert (isNaN(”10”)); //false(可以被轉換成數值10)
ale‘‘(isNaN(”blue”)); //true(不能轉換成教值)
alert (isNaN( true)); //false(可以被轉換成數值1)
南昌網站制作公司百恒網絡前端開發工程師總結,這個例子測試了5個不同的值。測試的第一個值是NaN本身,結果當然會速回t rue。然后分別測試了數值10和字符串”10”,結果這兩個測試都返回了false,因為前者本身就是數值,而后者可以被轉換成數值。但是,字符串”blue”不能被轉換成數值,因此函數返回了true。由于Boolean值 true可以轉換成數值1,因此函數返回false。
希望對廣大站長或網站建設公司或從事企業網站建設的團隊有所幫助,如對此不太理解的,可以與南昌網絡公司百恒網絡技術部聯系。我們很高與廣大站長和網站建設公司技術人員分享我們的技術和經驗。
專業專注于南昌網站建設,為用戶提供高品質的網絡產品和優質的服務是我們始終追求的目標!