Maison > interface Web > js tutoriel > Quels sont les opérateurs logiques en JavaScript ?

Quels sont les opérateurs logiques en JavaScript ?

青灯夜游
Libérer: 2021-11-04 16:43:50
original
10295 Les gens l'ont consulté

Les opérateurs logiques de JavaScript sont : 1. ET logique "&&", qui renvoie vrai uniquement lorsque les deux opérandes sont vrais ; 2. OU logique "||", si les deux opérandes sont vrais, ou si l'un d'eux est vrai, il renvoie vrai ; 3. Logique non "!", convertit la valeur de l'opérande en valeur booléenne et l'annule.

Quels sont les opérateurs logiques en JavaScript ?

L'environnement d'exploitation de ce tutoriel : système Windows 7, JavaScript version 1.8.5, ordinateur Dell G3.

Opérateurs logiques en JavaScript

Les opérateurs logiques sont généralement utilisés pour combiner plusieurs expressions. Le résultat d'un opérateur logique est une valeur booléenne, qui ne peut avoir que deux résultats, vrai ou faux. Le tableau suivant répertorie les opérateurs logiques pris en charge dans JavaScript :

Operator Name Example
&& Logical AND x && y signifie que si x et y sont vrais, alors est vrai
|| OR logique x|| y signifie que si x ou y est vrai, alors c'est vrai
 ! pas logique !x signifie que si x n'est pas vrai, alors c'est vrai

Opération ET logique

L'opération ET logique (&&) est une opération booléenne ET. Renvoie vrai uniquement si les deux opérandes sont vrais, sinon renvoie faux. La description détaillée est présentée dans le tableau. &&)是 AND 布尔操作。只有两个操作数都为 true 时,才返回 true,否则返回 false。具体描述如表所示。

逻辑与运算
第一个操作数 第二个操作数 运算结果
true true true
true 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("没有赋值"));  //返回提示信息“没有赋值”
Copier après la connexion

等效于:

var user;  //定义变量
if (! user){  //条件判断
    console.log("变量没有赋值");
}
Copier après la connexion

如果变量 user 的值为 0 或空字符串等假值转换为布尔值时,则为 false,那么当变量赋值之后,依然提示变量没有赋值。因此,在设计时必须确保逻辑与左侧的表达式返回值是一个可以预测的值。

var user = 0;  //定义并初始化变量
(! user && console.log("变量没有赋值"));  //返回提示信息“变量没有赋值”
Copier après la connexion

右侧表达式不应该包含赋值、递增、递减和函数调用等有效运算,因为当左侧表达式为 false 时,则直接跳过右侧表达式,会给后面的运算带来潜在影响。

逻辑或运算

逻辑或运算||

Opération ET logiquePremier opérandeDeuxième opérandeRésultat de l'opérationvraivraivraivraifaux fauxfauxvrai fauxfauxfauxfauxfaux
🎜🎜Le ET logique est une sorte de logique de court-circuit Si l'expression de gauche est fausse, le résultat sera court-circuité et. retourné sans aucune autre opération d'expression à droite. La logique de fonctionnement est la suivante : 🎜
  • 🎜Étape 1 : Calculez la valeur du premier opérande (expression à gauche). 🎜
  • 🎜Étape 2 : Vérifiez la valeur du premier opérande. Si la valeur de l'expression de gauche est convertible en faux (comme null, undefined, NaN, 0, "", false), alors l'opération se terminera et la valeur du premier opérande sera renvoyée directement. 🎜
  • 🎜Étape 3 : Si le premier opérande peut être converti en vrai, évaluez le deuxième opérande (l'expression de droite). 🎜
  • 🎜Étape 4 : Renvoyer la valeur du deuxième opérande. 🎜
🎜🎜Exemple 1🎜🎜🎜Le code suivant utilise des opérations ET logiques pour détecter les variables et les initialiser. 🎜
var n = 3;
(n == 1) && console.log(1);
(n == 2) && console.log(2);
(n == 3) && console.log(3);
( ! n ) && console.log("null");
Copier après la connexion
Copier après la connexion
🎜 est équivalent à : 🎜
var n = 3;
(n == 1) && console.log(1) || 
(n == 2) && console.log(2) || 
(n == 3) && console.log(3) || 
( ! n ) && console.log("null");
Copier après la connexion
Copier après la connexion
🎜 Si la valeur de la variable user est 0 ou si une valeur fausse telle qu'une chaîne vide est convertie en valeur booléenne, elle sera fausse. Ensuite, une fois que la variable aura reçu une valeur, elle le sera. indique toujours que la variable n'a pas reçu de valeur. Par conséquent, la conception doit garantir que l’expression située à gauche du ET logique renvoie une valeur prévisible. 🎜
var n = 3;
((n == 1) && console.log(1)) ||
((n == 2) && console.log(2)) ||
((n == 3) && console.log(3)) ||
(( ! n ) && console.log("null")) ||
Copier après la connexion
Copier après la connexion
🎜L'expression de droite ne doit pas contenir d'opérations valides telles que l'affectation, l'incrémentation, la décrémentation et l'appel de fonction, car lorsque l'expression de gauche est fausse, l'expression de droite sera ignorée directement, ce qui aura un potentiel impact sur les opérations ultérieures. 🎜🎜🎜🎜Opération OU logique🎜🎜🎜🎜Opération OU logique || est une opération OU booléenne. Si les deux opérandes sont vrais, ou si l’un d’eux est vrai, il renvoie vrai, sinon il renvoie faux. Les détails sont montrés dans la figure. 🎜🎜🎜Opération OU logique🎜🎜🎜🎜Premier opérande🎜🎜Deuxième opérande🎜🎜Résultat de l'opération🎜🎜🎜🎜vrai🎜🎜vrai🎜🎜vrai🎜🎜🎜🎜vrai🎜 🎜faux 🎜🎜vrai🎜🎜 🎜🎜faux🎜🎜vrai 🎜🎜vrai🎜🎜🎜🎜faux🎜🎜faux🎜🎜faux🎜🎜🎜🎜

逻辑或也是一种短路逻辑,如果左侧表达式为 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");
Copier après la connexion
Copier après la connexion

可以使用逻辑或对其进行合并:

var n = 3;
(n == 1) && console.log(1) || 
(n == 2) && console.log(2) || 
(n == 3) && console.log(3) || 
( ! n ) && console.log("null");
Copier après la connexion
Copier après la connexion

由于&&运算符的优先级高于||运算符的优先级,所以不必使用小括号进行分组。不过使用小括号分组后,代码更容易阅读。

var n = 3;
((n == 1) && console.log(1)) ||
((n == 2) && console.log(2)) ||
((n == 3) && console.log(3)) ||
(( ! n ) && console.log("null")) ||
Copier après la connexion
Copier après la connexion

逻辑与和逻辑或运算符具有以下 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
Copier après la connexion

示例4

如果对操作数执行两次逻辑非运算操作,就相当于把操作数转换为布尔值。

console.log( ! 0 );  //返回true
console.log( ! ! 0 );  //返回false
Copier après la connexion

逻辑与和逻辑或运算的返回值不必是布尔值,但是逻辑非运算的返回值一定是布尔值。

【推荐学习:javascript高级教程

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal