javascript數據類型轉換

 
JavaScript 類型轉換
 
 

轉換成字符串

    ECMAScript 的 Boolean 值、數字和字符串的原始值的有趣之處在於它們是僞對象,這意味着它們實際上具有屬性和方法。例如,要獲得字符串的長度,可以採用下面的代碼:
var sColor = "red";
alert(sColor.length); //輸出 "3"
儘管 "red" 是原始類型的字符串,它仍然具有屬性 length,用於存放字符串的大小。
總而言之,3 種主要的原始類型 Boolean 值、數字和字符串都有 toString() 方法,可以把它們的值轉換成字符串。
Boolean 類型的 toString() 方法只是輸出 "true" 或 "false",結果由變量的值決定:
var bFound = false;
alert(bFound.toString()); //輸出 "false"
Number 類型的 toString() 方法比較特殊,它有兩種模式,即默認模式和基模式。採用默認模式,toString() 方法只是用相應的字符串輸出數字值(無論是整數、浮點數還是科學計數法),如下所示:
var iNum1 = 10;
var iNum2 = 10.0;
alert(iNum1.toString()); //輸出 "10"
alert(iNum2.toString()); //輸出 "10"
註釋:在默認模式中,無論最初採用什麼表示法聲明數字,Number 類型的 toString() 方法返回的都是數字的十進制表示。因此,以八進制或十六進制字面量形式聲明的數字輸出的都是十進制形式的。
採用 Number 類型的 toString() 方法的基模式,可以用不同的基輸出數字,例如二進制的基是 2,八進制的基是 8,十六進制的基是 16。
基只是要轉換成的基數的另一種加法而已,它是 toString() 方法的參數:
var iNum = 10;
alert(iNum1.toString(2)); //輸出 "1010"
alert(iNum1.toString(8)); //輸出 "12"
alert(iNum1.toString(16)); //輸出 "A"
在前面的示例中,以 3 種不同的形式輸出了數字 10,即二進制形式、八進制形式和十六進制形式。HTML 採用十六進制表示每種顏色,在 HTML 中處理數字時這種功能非常有用。
註釋:對數字調用 toString(10) 與調用 toString() 相同,它們返回的都是該數字的十進制形式。


轉換成數字


ECMAScript 提供了兩種把非數字的原始值轉換成數字的方法,即 parseInt() 和 parseFloat()。前者把值轉換成整數,後者把值轉換成浮點數。只有對 String 類型調用這些方法,它們才能正確運行;對其他類型返回的都是 NaN。


       1.parseInt()
在判斷字符串是否是數字值前,parseInt() 和 parseFloat() 都會仔細分析該字符串。
parseInt() 方法首先查看位置 0 處的字符,判斷它是否是個有效數字;如果不是,該方法將返回 NaN,不再繼續執行其他操作。但如果該字符是有效數字,該方法將查看位置 1 處的字符,進行同樣的測試。這一過程將持續到發現非有效數字的字符爲止,此時 parseInt() 將把該字符之前的字符串轉換成數字。
例如,如果要把字符串 "12345red" 轉換成整數,那麼 parseInt() 將返回 12345,因爲當它檢查到字符 r 時,就會停止檢測過程。字符串中包含的數字字面量會被正確轉換爲數字,比如 "0xA" 會被正確轉換爲數字 10。不過,字符串 "22.5" 將被轉換成 22,因爲對於整數來說,小數點是無效字符。示例如下:
var iNum1 = parseInt("12345red"); //返回 12345
var iNum1 = parseInt("0xA"); //返回 10
var iNum1 = parseInt("56.9"); //返回 56
var iNum1 = parseInt("red"); //返回 NaN
parseInt() 方法還有基模式,可以把二進制、八進制、十六進制或其他任何進制的字符串轉換成整數。基是由 parseInt() 方法的第二個參數指定的,當然,對二進制、八進制、十六進制甚至十進制(默認模式),都可以調用 parseInt() 方法:
var iNum1 = parseInt("10", 2); //返回 2
var iNum2 = parseInt("10", 8); //返回 8
var iNum1 = parseInt("AF", 16); //返回 175
var iNum3 = parseInt("10", 10); //返回 10
如果十進制數包含前導 0,那麼最好採用基數 10,這樣纔不會意外地得到八進制的值。例如:
var iNum1 = parseInt("010"); //返回 8
var iNum2 = parseInt("010", 8); //返回 8
var iNum3 = parseInt("010", 10); //返回 10
在這段代碼中,兩行代碼都把字符 "010" 解析成一個數字。第一行代碼把這個字符串看作八進制的值,解析它的方式與第二行代碼(聲明基數爲 8)相同。最後一行代碼聲明基數爲 10,所以 iNum3 最後等於 10。


       2.parseFloat()
  parseFloat() 方法與 parseInt() 方法的處理方式相似,從位置 0 開始查看每個字符,直到找到第一個非有效的字符爲止,然後把該字符之前的字符串轉換成整數。
不過,對於這個方法來說,第一個出現的小數點是有效字符。如果有兩個小數點,第二個小數點將被看作無效的。parseFloat() 會把這個小數點之前的字符轉換成數字。這意味着字符串 "11.22.33" 將被解析成 11.22。使用 parseFloat() 方法的另一不同之處在於,字符串必須以十進制形式表示浮點數,而不是用八進制或十六進制。該方法會忽略前導 0,所以八進制數 0102 將被解析爲 102。對於十六進制數 0xA,該方法將返回 NaN,因爲在浮點數中,x 不是有效字符。此外,parseFloat() 方法也沒有基模式。下面是使用 parseFloat() 方法的一些示例:
var fNum1 = parseFloat("12345red"); //返回 12345
var fNum2 = parseFloat("0xA"); //返回 NaN
var fNum3 = parseFloat("11.2"); //返回 11.2
var fNum4 = parseFloat("11.22.33"); //返回 11.22
var fNum5 = parseFloat("0102"); //返回 102
var fNum1 = parseFloat("red"); //返回 NaN
強制類型轉換
您還可以使用強制類型轉換(type casting)來處理轉換值的類型。使用強制類型轉換可以訪問特定的值,即使它是另一種類型的。(注:cast 有“鑄造”之意,很貼合“強制轉換”的意思。)
ECMAScript 中可用的 3 種強制類型轉換如下:
Boolean(value) - 把給定的值轉換成 Boolean 型;
Number(value) - 把給定的值轉換成數字(可以是整數或浮點數);
String(value) - 把給定的值轉換成字符串;
用這三個函數之一轉換值,將創建一個新值,存放由原始值直接轉換成的值。這會造成意想不到的後果。


       1.Boolean() 函數
  當要轉換的值是至少有一個字符的字符串、非 0 數字或對象時,Boolean() 函數將返回 true。如果該值是空字符串、數字 0、undefined 或 null,它將返回 false。
可以用下面的代碼測試 Boolean 型的強制類型轉換:
var b1 = Boolean("");  //false - 空字符串
var b2 = Boolean("hello");  //true - 非空字符串
var b1 = Boolean(50);  //true - 非零數字
var b1 = Boolean(null);  //false - null
var b1 = Boolean(0);  //false - 零
var b1 = Boolean(new object()); //true - 對象


       2.Number() 函數
  Number() 函數的強制類型轉換與 parseInt() 和 parseFloat() 方法的處理方式相似,只是它轉換的是整個值,而不是部分值。
還記得嗎,parseInt() 和 parseFloat() 方法只轉換第一個無效字符之前的字符串,因此 "1.2.3" 將分別被轉換爲 "1" 和 "1.2"。用 Number() 進行強制類型轉換,"1.2.3" 將返回 NaN,因爲整個字符串值不能轉換成數字。如果字符串值能被完整地轉換,Number() 將判斷是調用 parseInt() 方法還是 parseFloat() 方法。下表說明了對不同的值調用 Number() 方法會發生的情況:
用法       結果
Number(false) 0
Number(true) 1
Number(undefined) NaN
Number(null) 0
Number("1.2") 1.2
Number("12") 12
Number("1.2.3") NaN
Number(new object()) NaN
Number(50) 50


       3.String() 函數
最後一種強制類型轉換方法 String() 是最簡單的,因爲它可把任何值轉換成字符串。
要執行這種強制類型轉換,只需要調用作爲參數傳遞進來的值的 toString() 方法,即把 12 轉換成 "12",把 true 轉換成 "true",把 false 轉換成 "false",以此類推。
強制轉換成字符串和調用 toString() 方法的唯一不同之處在於,對 null 和 undefined 值強制類型轉換可以生成字符串而不引發錯誤:
var s1 = String(null); //"null"
var oNull = null;
var s2 = oNull.toString(); //會引發錯誤
在處理 ECMAScript 這樣的弱類型語言時,強制類型轉換非常有用,不過應該確保使用值的正確。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章