javascript的邏輯運算子有:1、邏輯與“&&”,只有兩個運算元都為true時,才會傳回true;2、邏輯或“||”,如果兩個運算元都為true,或其中一個為true,就回傳true;3、邏輯非“!”,把操作數的值轉換為布林值,並取反。
本教學操作環境:windows7系統、javascript1.8.5版、Dell G3電腦。
邏輯運算子通常用來組合多個表達式,邏輯運算子的運算結果是一個布林值,只能有兩種結果,不是true就是false。下表中列舉了JavaScript 中支援的邏輯運算子:
#運算子 | 名稱 | #範例 |
---|---|---|
邏輯與x && y 表示如果x 和y 都為真,則為真
|| 邏輯或
邏輯非 | !x 表示如果x 不為真,則為真 | |
---|---|---|
#邏輯與運算 | ||
)是AND 布林運算。只有當兩個操作數都為 true 時,才會傳回 true,否則傳回 false。具體描述如表所示。 | 邏輯與運算 | |
#第二個運算元 | 運算結果 | |
true | true |
false
true
#false
邏輯與是一種短路邏輯,如果左側表達式為false,則直接短路回傳結果,不再運算右側表達式。運算邏輯如下: 第 1 步:計算第一個運算元(左側表達式)的值。 第 2 步:偵測第一個運算元的值。如果左側表達式的值可轉換為 false(如 null、undefined、NaN、0、""、false),那麼就會結束運算,直接傳回第一個運算元的值。
第 3 步:如果第一個運算元可以轉換為 true,則計算第二個運算元(右側表達式)的值。
第 4 步:傳回第二個運算元的值。
下面程式碼利用邏輯與運算偵測變數並進行初始化。 | 等效於: | 如果變數user 的值為0 或空字串等假值轉換為布林值時,則為false,那麼當變數賦值之後,依然提示變數沒有賦值。因此,在設計時必須確保邏輯與左側的表達式回傳值是一個可以預測的值。 |
---|---|---|
邏輯或運算 | ||
是布林 OR 運算。如果兩個運算元都為 true,或其中一個為 true,就回傳 true,否則回傳 false。具體如圖所示。 | 邏輯或運算 | |
第二個運算元 | 運算結果 | |
true | true |
逻辑或也是一种短路逻辑,如果左侧表达式为 true,则直接短路返回结果,不再运算右侧表达式。运算逻辑如下:
第 1 步:计算第一个操作数(左侧表达式)的值。
第 2 步:检测第一个操作数的值。如果左侧表达式的值可转换为 true,那么就会结束运算,直接返回第一个操作数的值。
第 3 步:如果第一个操作数可以转换为 false,则计算第二个操作数(右侧表达式)的值。
第 4 步:返回第二个操作数的值。
示例2
针对下面 4 个表达式:
var n = 3; (n == 1) && console.log(1); (n == 2) && console.log(2); (n == 3) && console.log(3); ( ! n ) && console.log("null");
可以使用逻辑或对其进行合并:
var n = 3; (n == 1) && console.log(1) || (n == 2) && console.log(2) || (n == 3) && console.log(3) || ( ! n ) && console.log("null");
由于&&运算符的优先级高于||运算符的优先级,所以不必使用小括号进行分组。不过使用小括号分组后,代码更容易阅读。
var n = 3; ((n == 1) && console.log(1)) || ((n == 2) && console.log(2)) || ((n == 3) && console.log(3)) || (( ! n ) && console.log("null")) ||
逻辑与和逻辑或运算符具有以下 2 个特点:
在逻辑运算过程中,临时把操作数转换为布尔值,然后根据布尔值决定下一步的操作,但是不会影响操作数的类型和最后返回结果。
受控于第一个操作数,可能不会执行第二个操作数。
逻辑非运算
逻辑非运算!
是布尔取反操作(NOT)。作为一元运算符,直接放在操作数之前,把操作数的值转换为布尔值,然后取反并返回。
示例3
下面列举一些特殊操作数的逻辑非运算返回值。
console.log( ! {} ); //如果操作数是对象,则返回false console.log( ! 0 ); //如果操作数是0,则返回true console.log( ! (n = 5)); //如果操作数是非零的任何数字,则返回false console.log( ! null ); //如果操作数是null,则返回true console.log( ! NaN ); //如果操作数是NaN,则返回true console.log( ! Infinity ); //如果操作数是Infinity,则返回false console.log( ! ( - Infinity )); //如果操作数是-Infinity,则返回false console.log( ! undefined ); //如果操作数是undefined,则返回true
示例4
如果对操作数执行两次逻辑非运算操作,就相当于把操作数转换为布尔值。
console.log( ! 0 ); //返回true console.log( ! ! 0 ); //返回false
逻辑与和逻辑或运算的返回值不必是布尔值,但是逻辑非运算的返回值一定是布尔值。
【推荐学习:javascript高级教程】
以上是javascript的邏輯運算子有哪些的詳細內容。更多資訊請關注PHP中文網其他相關文章!