Посмотрите на определение функции, которая возвращает модуль переданного числа:
const abs = (number) => {
if (number >= 0) {
return number;
}
return -number;
};
abs(10); // 10
abs(-10); // 10
Можно ли записать ее лаконичнее? Что-то вроде return <ответ в зависимости от условия>
? Для этого справа от return должно быть выражение, но if
— это инструкция, а не выражение.
В JavaScript существует конструкция, которая по своему действию аналогична конструкции if-else
, но при этом является выражением. Она называется тернарный оператор.
Тернарный оператор — единственный в своем роде оператор, требующий три операнда:
const abs = (number) => {
return number >= 0 ? number : -number;
};
Общий паттерн выглядит так: <predicate> ? <expression on true> : <expression on false>
.
Сокращенный вариант функции abs()
выглядит так:
const abs = (number) => (number >= 0 ? number : -number);
Обратите внимание на скобки вокруг тернарника. Они не обязательны, но линтер настоятельно рекомендует их ставить, во избежание неоднозначностей.
Давайте перепишем начальный вариант getTypeOfSentence()
аналогично:
Было:
const getTypeOfSentence = (sentence) => {
const lastChar = sentence.slice(-1);
if (lastChar === '?') {
return 'question';
}
return 'normal';
};
Стало:
const getTypeOfSentence = (sentence) => {
const lastChar = sentence.slice(-1);
return (lastChar === '?') ? 'question' : 'normal';
};
getTypeOfSentence('Hodor'); // normal
getTypeOfSentence('Hodor?'); // question
https://replit.com/@hexlet/js-basics-ternary-operator
Если вы помните, в чем сила выражений, то вероятно уже догадались, что тернарный оператор можно вкладывать в тернарный оператор. Не делайте этого :) Такой код тяжело и читать, и отлаживать, это очень плохая практика.
Вам ответят команда поддержки Хекслета или другие студенты.
Курсы программирования для новичков и опытных разработчиков. Начните обучение бесплатно
Наши выпускники работают в компаниях:
Зарегистрируйтесь или войдите в свой аккаунт