布爾操作符一共有三個(gè):
非(NOT)
,與(AND)
遏乔,或(OR)
义矛。
1.邏輯非
- 簡言之,將任何值轉(zhuǎn)換為一個(gè)布爾值按灶,并對(duì)其取反症革,返回結(jié)果始終為布爾值。
- 符號(hào)表示:
感嘆號(hào)(!)
- 遵守規(guī)則:
1.如果操作數(shù)為對(duì)象鸯旁,返回 false
2.如果操作數(shù)為字符串,空字符串返回 true量蕊;非空返回 false铺罢;
3.如果操作數(shù)為數(shù)值,0 返回 true残炮;任意非 0 數(shù)值返回 false韭赘;
4.如果操作數(shù)是 null,返回 true势就;
5.如果操作數(shù)是 NaN泉瞻,返回 true;
6.如果操作數(shù)是 undefined,返回 true趾徽。
??之前剛了解這些規(guī)則時(shí)沃缘,沒有做統(tǒng)一的總結(jié),總會(huì)對(duì)部分操作數(shù)感到疑惑鞭达。例如:
!'true'
司忱,!'false'
,!'0'
畴蹭,等等坦仍。歸根結(jié)底還是,自己沒有掌握邏輯非的規(guī)則∵督螅現(xiàn)在看來繁扎,這些沒什么好疑問的。
2.邏輯與
- 可以應(yīng)用于任何類型的操作數(shù)糊闽,而不僅僅是布爾值梳玫。如果其中一個(gè)操作數(shù)不是布爾值的情況,則不一定返回布爾值墓怀。
- 符號(hào)表示:
兩個(gè)和號(hào)(&&)
- 真值表:
第一個(gè)操作數(shù) | 第二個(gè)操作數(shù) | 結(jié)果 |
---|---|---|
true | true | true |
true | false | false |
false | true | false |
false | false | false |
- 遵守規(guī)則:
邏輯與屬于短路操作汽纠,這就意味著:
1.如果第一個(gè)操作數(shù)求值結(jié)果為false,就不會(huì)對(duì)第二個(gè)操作數(shù)求值傀履,直接返回第一個(gè)操作數(shù)的值虱朵;
2.如果第二個(gè)操作數(shù)求值結(jié)果為true,則返回第二個(gè)操作數(shù)的值钓账。
- e.g.
/*(對(duì)a值求值結(jié)果為false碴犬,不會(huì)繼續(xù)對(duì)b求值,直接返回a的值)*/
var a = null, b = '第二個(gè)操作數(shù)'梆暮;
console.log(a && b); // null
a = null; b = undefined服协;
console.log(a && b); // null
a = 0; b = '第二個(gè)操作數(shù)';
console.log(a && b); // 0
/*(對(duì)a值求值結(jié)果為true,繼續(xù)對(duì)b求值啦粹,無論求值結(jié)果偿荷,都直接返回b值)*/
a = []; b = '第二個(gè)操作數(shù)';
console.log(a && b); // 第二個(gè)操作數(shù)
a = {}; b = '第二個(gè)操作數(shù)';
console.log(a && b); // 第二個(gè)操作數(shù)
a = '第一個(gè)操作符'; b = null;
console.log(a && b); // null
3.邏輯或
- 可以應(yīng)用于任何類型的操作數(shù),而不僅僅是布爾值唠椭。如果其中一個(gè)操作數(shù)不是布爾值的情況跳纳,則不一定返回布爾值。
- 符號(hào)表示:
兩個(gè)豎線符號(hào)(||)
- 真值表:
第一個(gè)操作數(shù) | 第二個(gè)操作數(shù) | 結(jié)果 |
---|---|---|
true | true | true |
true | false | true |
false | true | true |
false | false | false |
- 遵守規(guī)則:
邏輯或?qū)儆诙搪凡僮魈吧@就意味著:
1.如果第一個(gè)操作數(shù)求值結(jié)果為true寺庄,則不會(huì)對(duì)第二個(gè)操作數(shù)去求值,直接返回第一個(gè)操作數(shù)值。
2.如果第一個(gè)操作數(shù)求值結(jié)果返回false斗塘,直接返回第二個(gè)操作數(shù)赢织。
- e.g.
/*(對(duì)a求值結(jié)果為true,則不對(duì)第二個(gè)操作數(shù)求值馍盟,直接返回a值)*/
var a =[], b = '第二個(gè)操作數(shù)'于置;
console.log(a || b); // []
a ={}; b = undefined;
console.log(a || b); // []
a = '第一個(gè)操作數(shù)'; b = '第二個(gè)操作數(shù)';
console.log(a || b); // 第一個(gè)操作數(shù)
/*(對(duì)a求值結(jié)果為false朽合,繼續(xù)對(duì)b進(jìn)行求值俱两,無論求值結(jié)果如何,直接返回b值)*/
a = null; b = '第二個(gè)操作數(shù)';
console.log(a || b); // 第二個(gè)操作數(shù)
a = undefined; b = null;
console.log(a || b); // null