首頁  >  文章  >  web前端  >  學習js中!和!!的區別及用法

學習js中!和!!的區別及用法

coldplay.xixi
coldplay.xixi轉載
2020-06-29 17:34:411960瀏覽

學習js中!和!!的區別及用法

在看別人的js程式碼時發現了這麼一個用法:

if (!!item.value) {
	param[item.name] = item.value;
}

好久沒研究js,所以趕緊補充了一下,還發現了一個特別好玩的東西。

推薦學習教學:javascript影片教學

#js中 ! 的用法是比較靈活的,它除了做邏輯運算常常會用!做類型判斷,可以用!與上物件來求得一個布林值,
#1、! 可將變數轉換成boolean型別,null、undefined和空字串取反都為true,其餘都為false。

!null=true

!undefined=true

!''=true

!100=false

!'abc'=false

2、! ! 常常用來做類型判斷,在第一步!(變數)之後再做邏輯取反運算,在js中新手常常會寫這樣臃腫的程式碼:
判斷變數a為非空,未定義或非空串才能執行方法體的內容。

var a;
if(a!=null&&typeof(a)!=undefined&&a!=''){
    //a有内容才执行的代码  
}

其實我們只需要寫一個判斷表達:

if(!!a){
    //a有内容才执行的代码...  
}

就能和上面達到同樣的效果。 a是有實際意義的變數才執行方法,否則變數null,undefined和'' "空字串都不會執行以下程式碼。

可以總結出來,「! 」是邏輯與運算,並且可以與任何變數進行邏輯與將其轉換為布林值,「!!」則是邏輯與的取反運算,尤其後者在判斷類型時程式碼簡潔高效,省去了多次判斷null、undefined和空字串的冗餘程式碼。

所以開頭的程式碼中,!!value , 先將value轉成取反的布林值,將得到的布林值再取反,保證value的值為null,undefined和空字串的情況下,if體中的程式碼不會執行。

???另發現的好玩的東西???:

(!(~ []) {})[--[~ ""][ []]*[~ []] ~~! []] ({} [])[[~! []]* ~ []]

輸出一下上面js的結果,emmmmm.....? ? ? ?

?...溜了溜了...

以上是學習js中!和!!的區別及用法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:csdn.net。如有侵權,請聯絡admin@php.cn刪除