- Операторы сравнения и логические операторы в JS
- Пример 2. Оператор не равно
- Пример 3. Оператор строго равно
- Пример 4. Оператор строго не равно
- Пример 5. Оператор больше
- Пример 6. Оператор больше или равно
- Пример 7. Оператор меньше
- Пример 8. Оператора меньше или равно
- Пример 2. Логический оператор OR
- Пример 3. Логический оператор NOT
- Условное ветвление: if, '?'
- Инструкция «if»
- Преобразование к логическому типу
- Блок «else»
- Несколько условий: «else if»
- Условный оператор „?“
- Несколько операторов „?“
- Нетрадиционное использование „?“
- Задачи
- if (строка с нулём)
- Название JavaScript
- Inequality (!=)
- Try it
- Syntax
- Description
- Examples
- Comparison with no type conversion
- Comparison with type conversion
- Comparison of objects
- Specifications
- Browser compatibility
- See also
- Found a content problem with this page?
- MDN
- Support
- Our communities
- Developers
- Истина или ложь?
- Видео
- Операторы равенства
- Равно ==
Операторы сравнения и логические операторы в JS
Примечание. Обратите внимание, что == — это оператор сравнения, а = — оператор присваивания. Не путайте их, иначе возникнет ошибка.
Пример 2. Оператор не равно
const a = 3, b = "привет"; // оператор не равно console.log(a != 2); // true console.log(b != "Привет"); // true
Оператор != возвращает true , если операнды не равны.
Пример 3. Оператор строго равно
const a = 2; // оператор строго равно console.log(a === 2); // true console.log(a === '2'); // false
Оператор === возвращает true , если операнды равны и принадлежат одному и тому же типу. Здесь 2 и ‘2’ — одинаковые числа, но тип данных у них разный.
Примечание. Разница между == и === заключается в том, что:
• оператор == возвращает true, если операнды равны
• оператор === возвращает true, только если операнды равны и имеют одинаковый тип.
Пример 4. Оператор строго не равно
const a = 2, b = "привет"; // оператор строго не равно console.log(a !== 2); // false console.log(a !== '2'); // true console.log(b !== "Привет"); // true
Оператор !== возвращает true , если операнды строго не равны. Это полная противоположность оператору строго равно === .
В приведенном выше примере 2 !== ‘2 ‘ возвращает true . Так происходит потому, что у них одинаковые значения, но разные типы.
Пример 5. Оператор больше
const a = 3; // оператора больше console.log(a > 2); // true
Операто > возвращает true , если левый операнд больше правого операнда.
Пример 6. Оператор больше или равно
const a = 3; // оператор больше или равно console.log(a >= 3); //true
Оператор >= возвращает true , если левый операнд больше правого операнда или равен ему.
Пример 7. Оператор меньше
const a = 3, b = 2; // оператор меньше console.log(a < 2); // false console.log(b < 3); // true
Пример 8. Оператора меньше или равно
const a = 2; // оператор меньше или равно console.log(a
Логические операторы в JavaScript
Логические операторы выполняют логические операции И (AND), ИЛИ (OR) и НЕ (NOT).
Пример 1. Логический оператор AND
const a = true, b = false; const c = 4; // логическое И console.log(a && a); // true console.log(a && b); // false console.log((c > 2) && (c < 2)); // false
Оператор && возвращает true , если оба операнда true , иначе возвращает false .
Примечание. Логические операторы можно использовать и с числами. В JavaScript 0 оценивается как false, все ненулевые значения — true.
Пример 2. Логический оператор OR
const a = true, b = false, c = 4; // логическое ИЛИ console.log(a || b); // true console.log(b || b); // false console.log((c>2) || (c<2)); // true
Оператор || возвращает true , если хотя бы один из операндов true . Если оба операнда false , результат — false .
Пример 3. Логический оператор NOT
const a = true, b = false; // логическое НЕ console.log(!a); // false console.log(!b); // true
Оператор ! возвращает true , если операнд false , и наоборот.
СodeСhick.io - простой и эффективный способ изучения программирования.
2023 © ООО "Алгоритмы и практика"
Условное ветвление: if, '?'
Иногда нам нужно выполнить различные действия в зависимости от условий.
Для этого мы можем использовать инструкцию if и условный оператор ? , который также называют оператором «вопросительный знак».
Инструкция «if»
Инструкция if(. ) вычисляет условие в скобках и, если результат true , то выполняет блок кода.
let year = prompt('В каком году была опубликована спецификация ECMAScript-2015?', ''); if (year == 2015) alert( 'Вы правы!' );
В примере выше, условие – это простая проверка на равенство ( year == 2015 ), но оно может быть и гораздо более сложным.
Если мы хотим выполнить более одной инструкции, то нужно заключить блок кода в фигурные скобки:
Мы рекомендуем использовать фигурные скобки <> всегда, когда вы используете инструкцию if , даже если выполняется только одна команда. Это улучшает читаемость кода.
Преобразование к логическому типу
Инструкция if (…) вычисляет выражение в скобках и преобразует результат к логическому типу.
Давайте вспомним правила преобразования типов из главы Преобразование типов:
- Число 0 , пустая строка "" , null , undefined и NaN становятся false . Из-за этого их называют «ложными» («falsy») значениями.
- Остальные значения становятся true , поэтому их называют «правдивыми» («truthy»).
Таким образом, код при таком условии никогда не выполнится:
…а при таком – выполнится всегда:
Мы также можем передать заранее вычисленное в переменной логическое значение в if , например так:
let condition = (year == 2015); // преобразуется к true или false if (condition)
Блок «else»
Инструкция if может содержать необязательный блок «else» («иначе»). Он выполняется, когда условие ложно.
let year = prompt('В каком году была опубликована спецификация ECMAScript-2015?', ''); if (year == 2015) < alert( 'Да вы знаток!' ); >else < alert( 'А вот и неправильно!' ); // любое значение, кроме 2015 >
Несколько условий: «else if»
Иногда нужно проверить несколько вариантов условия. Для этого используется блок else if .
let year = prompt('В каком году была опубликована спецификация ECMAScript-2015?', ''); if (year < 2015) < alert( 'Это слишком рано. ' ); >else if (year > 2015) < alert( 'Это поздновато' ); >else
В приведённом выше коде JavaScript сначала проверит year < 2015 . Если это неверно, он переходит к следующему условию year >2015 . Если оно тоже ложно, тогда сработает последний alert .
Блоков else if может быть и больше. Присутствие блока else не является обязательным.
Условный оператор „?“
Иногда нам нужно определить переменную в зависимости от условия.
let accessAllowed; let age = prompt('Сколько вам лет?', ''); if (age > 18) < accessAllowed = true; >else < accessAllowed = false; >alert(accessAllowed);
Так называемый «условный» оператор «вопросительный знак» позволяет нам сделать это более коротким и простым способом.
Оператор представлен знаком вопроса ? . Его также называют «тернарный», так как этот оператор, единственный в своём роде, имеет три аргумента.
let result = условие ? значение1 : значение2;
Сначала вычисляется условие : если оно истинно, тогда возвращается значение1 , в противном случае – значение2 .
let accessAllowed = (age > 18) ? true : false;
Технически, мы можем опустить круглые скобки вокруг age > 18 . Оператор вопросительного знака имеет низкий приоритет, поэтому он выполняется после сравнения > .
Этот пример будет делать то же самое, что и предыдущий:
// оператор сравнения "age > 18" выполняется первым в любом случае // (нет необходимости заключать его в скобки) let accessAllowed = age > 18 ? true : false;
Но скобки делают код более простым для восприятия, поэтому мы рекомендуем их использовать.
В примере выше вы можете избежать использования оператора вопросительного знака ? , т.к. сравнение само по себе уже возвращает true/false :
// то же самое let accessAllowed = age > 18;
Несколько операторов „?“
Последовательность операторов вопросительного знака ? позволяет вернуть значение, которое зависит от более чем одного условия.
let age = prompt('Возраст?', 18); let message = (age < 3) ? 'Здравствуй, малыш!' : (age < 18) ? 'Привет!' : (age < 100) ? 'Здравствуйте!' : 'Какой необычный возраст!'; alert( message );
Поначалу может быть сложно понять, что происходит. Но при ближайшем рассмотрении мы видим, что это обычная последовательная проверка:
Вот как это выглядит при использовании if..else :
if (age < 3) < message = 'Здравствуй, малыш!'; >else if (age < 18) < message = 'Привет!'; >else if (age < 100) < message = 'Здравствуйте!'; >else
Нетрадиционное использование „?“
Иногда оператор «вопросительный знак» ? используется в качестве замены if :
let company = prompt('Какая компания создала JavaScript?', ''); (company == 'Netscape') ? alert('Верно!') : alert('Неправильно.');
В зависимости от условия company == 'Netscape' , будет выполнена либо первая, либо вторая часть после ? .
Здесь мы не присваиваем результат переменной. Вместо этого мы выполняем различный код в зависимости от условия.
Не рекомендуется использовать оператор вопросительного знака таким образом.
Несмотря на то, что такая запись короче, чем эквивалентная инструкция if , она хуже читается.
Вот, для сравнения, тот же код, использующий if :
let company = prompt('Какая компания создала JavaScript?', ''); if (company == 'Netscape') < alert('Верно!'); >else
При чтении глаза сканируют код по вертикали. Блоки кода, занимающие несколько строк, воспринимаются гораздо легче, чем длинный горизонтальный набор инструкций.
Смысл оператора «вопросительный знак» ? – вернуть то или иное значение, в зависимости от условия. Пожалуйста, используйте его именно для этого. Когда вам нужно выполнить разные ветви кода – используйте if .
Задачи
if (строка с нулём)
Да, выведется.
Любая строка, кроме пустой (а строка "0" – не пустая), в логическом контексте становится true .
Можно запустить и проверить:
Название JavaScript
Используя конструкцию if..else , напишите код, который будет спрашивать: „Какое «официальное» название JavaScript?“
Если пользователь вводит «ECMAScript», то показать: «Верно!», в противном случае – отобразить: «Не знаете? ECMAScript!»
Inequality (!=)
The inequality ( != ) operator checks whether its two operands are not equal, returning a Boolean result. Unlike the strict inequality operator, it attempts to convert and compare operands that are of different types.
Try it
Syntax
Description
The inequality operator checks whether its operands are not equal. It is the negation of the equality operator so the following two lines will always give the same result:
For details of the comparison algorithm, see the page for the equality operator.
Like the equality operator, the inequality operator will attempt to convert and compare operands of different types:
To prevent this, and require that different types are considered to be different, use the strict inequality operator instead:
Examples
Comparison with no type conversion
1 != 2; // true "hello" != "hola"; // true 1 != 1; // false "hello" != "hello"; // false
Comparison with type conversion
"1" != 1; // false 1 != "1"; // false 0 != false; // false 0 != null; // true 0 != undefined; // true 0 != !!null; // false, look at Logical NOT operator 0 != !!undefined; // false, look at Logical NOT operator null != undefined; // false const number1 = new Number(3); const number2 = new Number(3); number1 != 3; // false number1 != number2; // true
Comparison of objects
const object1 = key: "value", >; const object2 = key: "value", >; console.log(object1 != object2); // true console.log(object1 != object1); // false
Specifications
Browser compatibility
BCD tables only load in the browser
See also
Found a content problem with this page?
This page was last modified on Feb 21, 2023 by MDN contributors.
Your blueprint for a better internet.
MDN
Support
Our communities
Developers
Visit Mozilla Corporation’s not-for-profit parent, the Mozilla Foundation.
Portions of this content are ©1998– 2023 by individual mozilla.org contributors. Content available under a Creative Commons license.
Истина или ложь?
В этой главе будет много нового, но уж очень сложно быть не должно: ведь, в общем-то, всё вертится вокруг простой идеи — истина или ложь?
До сих пор мы всегда имели дело лишь с примитивными типами данных — с числами и строками. Быть может, вам уже встречался термин "примитивный" применительно к программированию? Если нет, я поясню: "примитивный" (ещё говорят "простой") означает, что этот тип данных не является объектом (к этому моменту мы ещё вернёмся) и не имеет встроенных методов работы (то есть функций⚙️).
Тип данных, который вам обязательно понадобятся, называется булевым boolean , или логическим. Булевый тип всегда имеет значение либо true - истина, либо false - ложь. И только так, и никак иначе! Он либо врёт, либо говорит правду — пан или пропал, свет включен или выключен, либо есть, либо нет. Вы либо сделали домашнее задание, либо нет. Только два 2️⃣ значения true или false .
Видео
Операторы равенства
Булевы значения приходятся как нельзя кстати, когда нам необходимо что-то сравнить в JavaScript. Когда такая необходимость появляется, мы сразу же вызываем операторы сравнения. Сейчас мы последовательно изучим все восемь операторов сравнения, но штука в том, что в результате работы каждого из них мы всё равно всегда останемся с булевым значением — либо true , либо false .
Равно ==
Оператор равно сначала приводит операнды к одному типу, и затем применяет строгое сравнение. Если оба операнда являются объектами, то JavaScript сравнивает внутренние ссылки, которые равны в том случае, если они ссылаются на один и тот же объект в памяти.