經常看到這樣的例子:
var a;
var b=!!a;
a默認是undefined,!a是true,!!a則是false,所以b的值是false,而不再是undefined,也非其它值,主要是為后續判斷提供便利,
!!一般用來將后面的運算式強制轉換為布爾型別的資料(boolean),也就是只能是true或者false;
因為javascript是弱型別的語言(變數沒有固定的資料型別)所以有時需要強制轉換為相應的型別,類似的如:
- 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,
文章來自:https://www.html.cn/archives/4545
轉載請註明出處,本文鏈接:https://www.uj5u.com/qiye/144302.html
標籤:JavaScript
