常看到這樣的例子:
程式碼如下:
var;
var b=!!a;
a預設是undefined。 !a是true,!!a則是false,所以b的值是false,而不再是undefined,也非其它值,主要是為後續判斷提供便利。
複製程式碼
程式碼如下:
a=parseInt(“1234″)
a=”1234″-0 //轉換為數字
b=1234 ”” //轉換為字串
c=someObject. toString() //將物件轉換為字串
其中第1種、第4種為明確轉換,2、3為隱式轉換
布林型的轉換,javascript約定規則為
false、undefinded、null、0、”” 為false
true、1、”somestring”、[Object] 為true
對null與undefined等其他用隱式轉換的值,用!操作符時都會產生true的結果,所以用兩個感嘆號的作用就在於將這些值轉換為“等價”的布爾值; 再來看看: 複製程式碼
程式碼如下:
var foo;
alert(!foo); undifined情況下,一個感嘆號回傳的是true;
alert(!goo);//null情況下,一個感嘆號回傳的是true;
var o={flag:true};
var test =!!o.flag;//等效於var test=o.flag||false; alert(test); 這段例子,示範了在undifined和null時,用一個感嘆號回傳的都是true,用兩個感嘆號回傳的就是false,所以兩個感嘆號的作用就在於,如果明確設定了變數的值(非null/undifined/0/」「等值),結果就會根據變數的實際值來傳回,如果沒有設置,結果就會回傳false。