首頁  >  文章  >  web前端  >  javascript的邏輯運算子有哪些

javascript的邏輯運算子有哪些

青灯夜游
青灯夜游原創
2021-11-04 16:43:5010201瀏覽

javascript的邏輯運算子有:1、邏輯與“&&”,只有兩個運算元都為true時,才會傳回true;2、邏輯或“||”,如果兩個運算元都為true,或其中一個為true,就回傳true;3、邏輯非“!”,把操作數的值轉換為布林值,並取反。

javascript的邏輯運算子有哪些

本教學操作環境:windows7系統、javascript1.8.5版、Dell G3電腦。

javascript中的邏輯運算子

邏輯運算子通常用來組合多個表達式,邏輯運算子的運算結果是一個布林值,只能有兩種結果,不是true就是false。下表中列舉了JavaScript 中支援的邏輯運算子:

#&&
#運算子 名稱 #範例

邏輯與x && y 表示如果x 和y 都為真,則為真

|| 邏輯或

x || y 表示如果x 或y 有一個為真,則為真!邏輯非!x 表示如果x 不為真,則為真邏輯與運算(&&邏輯與運算第一個運算元#第二個運算元運算結果truetruetrue#true
#邏輯與運算
)是AND 布林運算。只有當兩個操作數都為 true 時,才會傳回 true,否則傳回 false。具體描述如表所示。

false

    false
  • false
  • true

  • false
  • false
  • #false

  • false

邏輯與是一種短路邏輯,如果左側表達式為false,則直接短路回傳結果,不再運算右側表達式。運算邏輯如下:

第 1 步:計算第一個運算元(左側表達式)的值。

第 2 步:偵測第一個運算元的值。如果左側表達式的值可轉換為 false(如 null、undefined、NaN、0、""、false),那麼就會結束運算,直接傳回第一個運算元的值。

第 3 步:如果第一個運算元可以轉換為 true,則計算第二個運算元(右側表達式)的值。

第 4 步:傳回第二個運算元的值。

範例1
var user;  //定义变量
(! user && console.log("没有赋值"));  //返回提示信息“没有赋值”
var user;  //定义变量
if (! user){  //条件判断
    console.log("变量没有赋值");
}
var user = 0;  //定义并初始化变量
(! user && console.log("变量没有赋值"));  //返回提示信息“变量没有赋值”
右側表達式不應該包含賦值、遞增、遞減和函數呼叫等有效運算,因為當左側表達式為false 時,則直接跳過右側表達式,會給後面的運算帶來潛在影響。 邏輯或運算||邏輯或運算第一個運算元第二個運算元運算結果truetruetrue#true
下面程式碼利用邏輯與運算偵測變數並進行初始化。 等效於:如果變數user 的值為0 或空字串等假值轉換為布林值時,則為false,那麼當變數賦值之後,依然提示變數沒有賦值。因此,在設計時必須確保邏輯與左側的表達式回傳值是一個可以預測的值。
邏輯或運算
是布林 OR 運算。如果兩個運算元都為 true,或其中一個為 true,就回傳 true,否則回傳 false。具體如圖所示。
###false##### #true############false######true######true############false######false# #####false############

逻辑或也是一种短路逻辑,如果左侧表达式为 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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn