久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

js中!和!!的區別與用法

瀏覽:148日期:2024-05-09 09:10:30

js中!的用法是比較靈活的,它除了做邏輯運算常常會用!做類型判斷,可以用!與上對象來求得一個布爾值,

1、!可將變量轉換成boolean類型,null、undefined和空字符串取反都為false,其余都為true。

!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和空字符串的冗余代碼。

下面是其他網友的補充

js 中 !!的用法

!!是將表達式強制轉化為bool值的運算,運算結果為true或false,表達式是什么值,結果就是對應的bool值,不再取非。

不是取非再取非的意思?。。?/p>

!!false=false; 要注意false和“false” 的區別?。。。?!

!!'false'=true;

!!true=true;

!!(NaN || undefined || null || 0 || ’ ’)=false;

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。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 国产91网址 | 成人综合在线观看 | 五月天中文字幕 | 天天干 夜夜操 | 久久三区 | 99精品国产热久久91蜜凸 | 成人免费crm在线观看 | 国产一区二区精品在线观看 | 黄色毛片免费看 | 在线h观看 | 欧美精品一区二区三区在线四季 | 国产精品国产自产拍高清 | 亚洲一区视频 | 夸克满天星在线观看 | 久久九九| 免费国产一区二区 | 国产福利在线播放 | 国产视频一区在线 | 成人毛片视频网站 | 亚洲 欧美 激情 另类 校园 | 国产 欧美 日韩 一区 | av一区二区三区在线观看 | 97色综合 | 亚洲在线免费观看 | 亚洲精品一区在线观看 | 日韩精品一区二区三区在线观看 | 免费国产视频 | 国产精品一区二区三区免费 | 欧美日本免费一区二区三区 | 四虎免费紧急入口观看 | 一区二区三区视频在线 | 高清av一区 | 精品综合 | 色婷婷国产精品免费网站 | 蜜桃官网| 日韩免费在线观看视频 | 久久久精品高清 | 成人免费视频一区二区 | a毛片毛片av永久免费 | 综合在线视频 | 狠狠色综合欧美激情 |