1. 程式人生 > 實用技巧 >JavaScript中雙歎號(!!)作用

JavaScript中雙歎號(!!)作用

經常看到這樣的例子:

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約定規則為

  1. false、undefinded、null、0、”” 為 false
  2. true、1、”somestring”、[Object] 為 true

對null與undefined等其他用隱式轉換的值,用!操作符時都會產生true的結果,所以用兩個感嘆號的作用就在於將這些值轉換為“等價”的布林值;

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

後來去網上查了些資料,他相當於三元運算子,返回boolean值:

var ret = !!document.getElementById

等價於

var ret = document.getElementById ? true : false;

當值是非空字串和非零數字返回true,當值是空字串、0或者null返回false

var a = " "; alert(!!a);   //true
var a = "s"; alert(!!a);   //true
var a = true; alert(!!a);   //true
var a = 1; alert(!!a);   //true
var a = -1; alert(!!a);   //true
var a = -2; alert(!!a);   //true
 
var a = 0; alert(!!a);   //
false var a = ""; alert(!!a); //false var a = false; alert(!!a); //false var a = null; alert(!!a); //false