您好,登錄后才能下訂單哦!
!!一般用來將后面的表達式強制轉換為布爾類型的數據(boolean),也就是只能是true或者false。
var a; var b=!!a;
a默認是undefined。!a是true,!!a則是false,所以b的值是false,而不再是undefined,也非其它值,主要是為后續判斷提供便利。
因為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。
JS中的“!!”
var o={flag:true}; var test=!!o.flag;//等效于var test=o.flag||false; alert(test);
由于對null與undefined用!操作符時都會產生true的結果,
所以用兩個感嘆號的作用就在于,
如果明確設置了o中flag的值(非 null/undefined/0""/等值),自然test就會取跟o.flag一樣的值;
如果沒有設置,test就會默認為false,而不是 null或undefined。
總結
以上所述是小編給大家介紹的JS中的!!,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對億速云網站的支持!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。