DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> JavaScript類型轉換方法及需要注意的問題小結(挺全面)
JavaScript類型轉換方法及需要注意的問題小結(挺全面)
編輯:關於JavaScript     
一、類型轉換的方法和應該注意的問題:
1.轉換為布爾型:
(1)用兩次非運算(!):
!!5 ==> true
(2)用布爾型的構造函數:
new Boolean(5) == > true
值轉換為布爾類型為false:
0,+0,-0,NaN,""(空字符串),undefined,null
除上面的值其他值在轉換以後為true,需要特別提到的是:
"0",new Object(),function(){}
2.轉換為字符串類型:
(1)加上空字符串"":
123 + "" = "123"
(2)用字符串構造函數:
new String(123) = "123".
需要特別注意的轉化:
+0 ==> "0"
-0 ==> "0"
-Infinity ==>"-Infinity"
+Infinity ==>"+Infinity"
NaN ==> "NaN"
undefined ==> "undefined"
null ==> "null"
new Object() ==> "[object Object]"
function(){} ==> "function(){}"
3.轉換為數值型:
(1) 取正(+), 減零 (-0), 乘一,(*1),除以一(/1),取負(-,這個得到相反的值)。
+"123" = 123
+true = 1
(2)用構造函數Number();
new Number("123") = 123
幾個需要特別注意的轉化:
""(空字符串) ==> 0
"010" ==> 10
"0x10"(16進制) ==> 16
"-010" ==> -10
"-0x10" ==> NaN
undefined ==> NaN
null ==> 0
true ==> 1
false ==> 0
new Object() ==> NaN
new function(){} ==> NaN

二、隱式類型轉換:
(1)二元加法運算(+):如果兩個操作數中有一個是String類型,將把兩個操作數轉換為String類型再相加。
如果兩個操作數中沒有字符串類型,那麼將把兩個操作數轉換為數值類型再做運算。
舉例:
"123"+123 = "123123";
123+123 = 246
true + true = 2
true + undefined = NaN (因為undefined轉換為數值為NaN,所有結果為NaN)
true + null = 1 (null轉換為數字是0)
"123" + null = "123null" (包含字符串將轉化為字符串相加)
"123" + undefined = "123undefined" (undefined同樣適用)
1 + 2 + "123" = "3123" (1+2是首先按照數值型計算的)
(2)二元減乘除運算(-*/):因為只有數值類型才有 - * / 運算,所以會先將兩個操作數轉換為數值型再做運算。
"123"-123 = 0
(3)一元取正(+),取負運算符(-):取正或者取負都是針對數值型的運算,所以會將操作數轉換為數值型再做運算。
+"123" = 123
-"123" = -123
+"123e" = NaN
+"123f" = NaN
+"123e-2" = 1.23 
(4)一元非(!)運算符:非運算符需要將操作數轉化為布爾類型。
!"123" = false
!!"123" = true
!123 = false
!!123 = true
(5)邏輯運算符(&&)和(||):
在&&或者||的兩側被判斷的時候會被轉為布爾類型進行判斷,
但是我在測試的時候卻發現一個有趣的事情。
&&運算符:如果有一個項為false,那麼表達式返回false,如果所有的項都不為false,那麼表達式返回最右邊一個項的原始值。
舉例:
123 && 23 && 45 返回 45,而不是我們想象中的true.
所以如果有 123 && 23 == true 那麼應該是false。
至於if(123 && 23) 認為是true那應該是把23轉換為布爾類型了。
||運算符:
對 || 測試的結果也和我想象的不一樣,|| 返回第一個轉換以後不為false的值,如果都為false,它將返回最後一個為false的值(未進行類型轉化之前的值)。
舉例: 
123 || 23 返回 123,而不是想象中的true.
false || null 返回null, 而不是想象中的false。
三、類型轉換函數
1.parseFloat轉換為浮點數:
字符解析函數獲取每一個字符直到遇到不屬於數值的字符,然後返回它已獲取的數值.
幾個需要特別注意的:
""(空字符串) ==> NaN
"123e-2" == > 1.23 (科學計算法是可以識別的)
"010" ==> 10 (8進制不能識別)
"0x10"==> 0 (16進制不識別)
"-010" ==> -10 
null,undefined,true,false,new Object(),function(){} ==> NaN
2.parseInt轉換為有符號整數:
跟parseFloat相似,但是他會把小數位捨掉(注意不是四捨五入,是完全捨棄,跟Math.floor處理方式一樣),而且他可以識別八進制和16進制表示方式:
123e-2 == > 1
"123e-2" ==> 123
"010" == > 8 
"0x10" ==> 16
"-010" == > -8 
"-0x10" ==> -16
null,undefined,true,false,new Object(),function(){},-Infinity +Infinity NaN ==> NaN
3.三個取整函數的區別
(1)Math.ceil():“天花板”,很形象吧?就是取大於等於參數的最小整數。
8.7 == > 9
-8.7==> -8
(2)Math.floor():"地板",取小於等於參數的最小整數。
8.7 ==> 8
-8.7 ==> -9
(3)Math.round():"四捨五入"取整數。
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved