aboutsummaryrefslogtreecommitdiff
path: root/files/ru/web/javascript/reference/operators/logical_and/index.md
diff options
context:
space:
mode:
Diffstat (limited to 'files/ru/web/javascript/reference/operators/logical_and/index.md')
-rw-r--r--files/ru/web/javascript/reference/operators/logical_and/index.md163
1 files changed, 163 insertions, 0 deletions
diff --git a/files/ru/web/javascript/reference/operators/logical_and/index.md b/files/ru/web/javascript/reference/operators/logical_and/index.md
new file mode 100644
index 0000000000..960d6ef3d1
--- /dev/null
+++ b/files/ru/web/javascript/reference/operators/logical_and/index.md
@@ -0,0 +1,163 @@
+---
+title: Логическое И (&&)
+slug: Web/JavaScript/Reference/Operators/Logical_AND
+tags:
+ - JavaScript
+ - Language feature
+ - Logical Operator
+ - Operator
+ - Reference
+browser-compat: javascript.operators.logical_and
+---
+{{jsSidebar("Operators")}}
+
+Логический оператор И (`&&`) (конъюнкция) для набора операндов со значением типа {{jsxref("Boolean")}} будет `true` только в случае, если все операнды содержат значение `true`. В противном случае это будет `false`.
+
+В целом, оператор вернёт значение первого {{Glossary("falsy", "ложноподобного")}} операнда при вычислении, либо значение последнего операнда, если все операнды оказались {{Glossary("truthy", "истиноподобными")}}.
+
+{{EmbedInteractiveExample("pages/js/expressions-logical-and.html", "shorter")}}
+
+## Синтаксис
+
+```js
+expr1 && expr2
+```
+
+## Описание
+
+Логическое И (`&&`) вычисляет операнды слева направо, возвращая сразу значение первого попавшего {{Glossary("falsy", "ложноподобного")}} операнда; если все значения {{Glossary("truthy", "истиноподобны")}}, возвращается значение последнего операнда.
+
+Если значение может быть преобразовано в `true`, то оно рассматривается как {{Glossary("truthy", "истиноподобное (truthy)")}}. Если же значение может быть преобразовано в `false`, то оно называется {{Glossary("falsy", "ложноподобным (falsy)")}}.
+
+Примеры выражений, которые могут быть преобразованы в `false`:
+
+- `false`;
+- `null`;
+- `NaN`;
+- `0`;
+- пустая строка (`""`, `''`, ` `` `);
+- `undefined`.
+
+Оператор И возвращает небулевы значения как есть:
+
+```js
+result = '' && 'foo'; // result is assigned "" (empty string)
+result = 2 && 0; // result is assigned 0
+result = 'foo' && 4; // result is assigned 4
+```
+
+Несмотря на то, что оператор `&&` может использоваться с операндами, не содержащие логических значений, он всё равно останется булевым оператором, поскольку его возвращаемое значение всегда можно преобразовать в [булевый примитив](/ru/docs/Web/JavaScript/Data_structures#Boolean_type).
+Чтобы явно преобразовать возвращаемое значение этого оператора (или вообще любое выражение) в соответствующее значение булевого типа, используйте двойной [`оператор НЕ`](/en-US/docs/Web/JavaScript/Reference/Operators/Logical_NOT) или конструктор {{jsxref("Global_Objects/Boolean/Boolean", "Boolean")}}.
+
+### Сокращённое вычисление
+
+Оператор логического И вычисляет выражение по сокращённой схеме.
+Каждый операнд приводится к булевому значению, если результат одного преобразования оказывается `false`, тогда оператор И останавливает дальнейшее вычисление выражения и возвращает исходное значение этого ложноподобного операнда. Поэтому оставшиеся операнды **не** будут вычислены.
+
+В качестве примера рассмотрим следующий псевдокод.
+
+```
+(ложноподобное выражение) && следующее выражение
+```
+
+Поскольку первый операнд `(ложноподобное выражение)` имеет ложное значение, то `следующее выражение` **никогда не будет вычислено**.
+Если `следующее выражение` содержало функцию, то она бы никогда не была вызвана.
+Посмотрите пример ниже:
+
+```js
+function A() { console.log('вызвана функция A'); return false; }
+function B() { console.log('вызвана функция B'); return true; }
+
+console.log( A() && B() );
+// В результате вызова функции A, в консоли будет выведено "вызвана функция A",
+// а оператор && вычислится как false (функция A возвращает false), поэтому далее в консоли появится false;
+// вследствие этого оператор И прекратит вычисление и проигнорирует функцию B
+```
+
+### Приоритет операторов
+
+Оператор И имеет более высокий приоритет, чем оператор ИЛИ, поэтому оператор `&&` выполнится раньше оператора `||` (см. [приоритет операторов](/en-US/docs/Web/JavaScript/Reference/Operators/Operator_Precedence)).
+
+```js
+false || true && true // вернёт true
+true && (false || false) // вернёт false
+(2 == 3) || (4 < 0) && (1 == 1) // вернёт false
+```
+
+## Примеры
+
+### Использование оператора И
+
+В следующем коде показаны примеры использования оператора `&&` (логическое И).
+
+```js
+a1 = true && true // t && t вернёт true
+a2 = true && false // t && f вернёт false
+a3 = false && true // f && t вернёт false
+a4 = false && (3 == 4) // f && f вернёт false
+a5 = 'Cat' && 'Dog' // t && t вернёт "Dog"
+a6 = false && 'Cat' // f && t вернёт false
+a7 = 'Cat' && false // t && f вернёт false
+a8 = '' && false // f && f вернёт ""
+a9 = false && '' // f && f вернёт false
+```
+
+### Правила преобразования булевых значений
+
+#### Конвертация И к ИЛИ
+
+Следующая операция с **булевыми значениями**:
+
+```js
+bCondition1 && bCondition2
+```
+
+всегда эквивалентна:
+
+```js
+!(!bCondition1 || !bCondition2)
+```
+
+#### Конвертация ИЛИ к И
+
+Следующая операция с **булевыми значениями**:
+
+```js
+bCondition1 || bCondition2
+```
+
+всегда эквивалентна:
+
+```js
+!(!bCondition1 && !bCondition2)
+```
+
+### Удаление вложенных круглых скобок
+
+Поскольку логические выражения вычисляются слева направо, всегда можно удалить круглые скобки из сложного выражения при условии соблюдения определенных правил.
+
+Следующая составная операция с **булевыми значениями**:
+
+```js
+bCondition1 || (bCondition2 && bCondition3)
+```
+
+это то же самое, что и:
+
+```js
+bCondition1 || bCondition2 && bCondition3
+```
+
+## Спецификации
+
+{{Specifications}}
+
+## Поддержка браузерами
+
+{{Compat}}
+
+## Смотрите также
+
+- {{jsxref("Boolean")}}
+- {{Glossary("Truthy")}}
+- {{Glossary("Falsy")}}