Heim > Web-Frontend > js-Tutorial > Hauptteil

Was sind die logischen Operatoren in Javascript?

青灯夜游
Freigeben: 2021-11-04 16:43:50
Original
10210 Leute haben es durchsucht

Die logischen Operatoren von JavaScript sind: 1. Logisches UND „&&“, das nur dann wahr ist, wenn beide Operanden wahr sind. 2. Logisches ODER „||“, wenn beide Operanden wahr sind, oder wenn einer von ihnen wahr ist. es gibt true zurück; 3. Logisch, nicht „!“, wandelt den Wert des Operanden in einen booleschen Wert um und negiert ihn.

Was sind die logischen Operatoren in Javascript?

Die Betriebsumgebung dieses Tutorials: Windows 7-System, JavaScript-Version 1.8.5, Dell G3-Computer.

Logische Operatoren in JavaScript

Logische Operatoren werden normalerweise verwendet, um mehrere Ausdrücke zu kombinieren. Das Ergebnis eines logischen Operators ist ein boolescher Wert, der nur zwei Ergebnisse haben kann, entweder wahr oder falsch. In der folgenden Tabelle sind die in JavaScript unterstützten logischen Operatoren aufgeführt:

Operator Name Beispiel
&& Logisches UND x && y bedeutet, dass, wenn sowohl x als auch y wahr sind, dann wahr ist
|| logisches ODER x||. y bedeutet, wenn entweder x oder y wahr ist, dann ist es wahr
! logisch nicht !x bedeutet, wenn x nicht wahr ist, dann es ist wahr

Logische UND-Verknüpfung

Die logische UND-Verknüpfung (&&) ist eine boolesche UND-Verknüpfung. Gibt nur dann „true“ zurück, wenn beide Operanden wahr sind, andernfalls wird „false“ zurückgegeben. Die detaillierte Beschreibung finden Sie in der Tabelle. &&)是 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("没有赋值"));  //返回提示信息“没有赋值”
Nach dem Login kopieren

等效于:

var user;  //定义变量
if (! user){  //条件判断
    console.log("变量没有赋值");
}
Nach dem Login kopieren

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

var user = 0;  //定义并初始化变量
(! user && console.log("变量没有赋值"));  //返回提示信息“变量没有赋值”
Nach dem Login kopieren

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

逻辑或运算

逻辑或运算||

Logische UND-VerknüpfungErster OperandZweiter OperandOperationsergebniswahrwahrwahrwahrfalsch falschfalschwahr falsefalsefalsefalsefalse
🎜🎜Logisches UND ist eine Art Kurzschlusslogik. Wenn der Ausdruck auf der linken Seite falsch ist, wird das Ergebnis kurzgeschlossen wird ohne weitere Operationen auf der rechten Seite zurückgegeben. Die Operationslogik ist wie folgt: 🎜
  • 🎜Schritt 1: Berechnen Sie den Wert des ersten Operanden (Ausdruck links). 🎜
  • 🎜Schritt 2: Überprüfen Sie den Wert des ersten Operanden. Wenn der Wert des Ausdrucks auf der linken Seite in „false“ konvertierbar ist (z. B. null, undefiniert, NaN, 0, „“, false), wird die Operation beendet und der Wert des ersten Operanden wird direkt zurückgegeben. 🎜
  • 🎜Schritt 3: Wenn der erste Operand in „True“ konvertiert werden kann, werten Sie den zweiten Operanden aus (Ausdruck auf der rechten Seite). 🎜
  • 🎜Schritt 4: Geben Sie den Wert des zweiten Operanden zurück. 🎜
🎜🎜Beispiel 1🎜🎜🎜Der folgende Code verwendet logische UND-Operationen, um Variablen zu erkennen und zu initialisieren. 🎜
var n = 3;
(n == 1) && console.log(1);
(n == 2) && console.log(2);
(n == 3) && console.log(3);
( ! n ) && console.log("null");
Nach dem Login kopieren
Nach dem Login kopieren
🎜 ist äquivalent zu: 🎜
var n = 3;
(n == 1) && console.log(1) || 
(n == 2) && console.log(2) || 
(n == 3) && console.log(3) || 
( ! n ) && console.log("null");
Nach dem Login kopieren
Nach dem Login kopieren
🎜 Wenn der Wert der Variablen user 0 ist oder ein falscher Wert, z. B. eine leere Zeichenfolge, in einen booleschen Wert konvertiert wird, ist er falsch, nachdem der Variablen ein Wert zugewiesen wurde immer noch die Meldung, dass der Variablen kein Wert zugewiesen wurde. Daher müssen Sie beim Entwerfen sicherstellen, dass der Rückgabewert des Ausdrucks auf der linken Seite des logischen UND ein vorhersehbarer Wert ist. 🎜
var n = 3;
((n == 1) && console.log(1)) ||
((n == 2) && console.log(2)) ||
((n == 3) && console.log(3)) ||
(( ! n ) && console.log("null")) ||
Nach dem Login kopieren
Nach dem Login kopieren
🎜Der rechte Ausdruck sollte keine gültigen Operationen wie Zuweisung, Inkrementierung, Dekrementierung und Funktionsaufruf enthalten, denn wenn der linke Ausdruck falsch ist, wird der rechte Ausdruck direkt übersprungen, was ein Potenzial hat Auswirkungen auf spätere Operationen. 🎜🎜🎜🎜Logische ODER-Verknüpfung🎜🎜🎜🎜Die logische ODER-Verknüpfung || ist eine boolesche ODER-Verknüpfung. Wenn beide Operanden wahr sind oder einer von ihnen wahr ist, wird „true“ zurückgegeben, andernfalls wird „false“ zurückgegeben. Die Details sind in der Abbildung dargestellt. 🎜🎜🎜Logische ODER-Verknüpfung🎜🎜🎜🎜Erster Operand🎜🎜Zweiter Operand🎜🎜Operationsergebnis🎜🎜🎜🎜wahr🎜🎜wahr🎜🎜wahr🎜🎜🎜🎜wahr🎜 🎜falsch 🎜🎜wahr🎜🎜 🎜🎜falsch🎜🎜wahr 🎜🎜wahr🎜🎜🎜🎜falsch🎜🎜falsch🎜🎜falsch🎜🎜🎜🎜

逻辑或也是一种短路逻辑,如果左侧表达式为 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");
Nach dem Login kopieren
Nach dem Login kopieren

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

var n = 3;
(n == 1) && console.log(1) || 
(n == 2) && console.log(2) || 
(n == 3) && console.log(3) || 
( ! n ) && console.log("null");
Nach dem Login kopieren
Nach dem Login kopieren

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

var n = 3;
((n == 1) && console.log(1)) ||
((n == 2) && console.log(2)) ||
((n == 3) && console.log(3)) ||
(( ! n ) && console.log("null")) ||
Nach dem Login kopieren
Nach dem Login kopieren

逻辑与和逻辑或运算符具有以下 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
Nach dem Login kopieren

示例4

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

console.log( ! 0 );  //返回true
console.log( ! ! 0 );  //返回false
Nach dem Login kopieren

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

【推荐学习:javascript高级教程

Das obige ist der detaillierte Inhalt vonWas sind die logischen Operatoren in Javascript?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage