Почему нельзя объявить константу без указания значения
Перейти к содержимому

Почему нельзя объявить константу без указания значения

  • автор:

JavaScript: undefined

Объявление переменных возможно и без указания конкретного значения. Что будет выведено на экран если её распечатать?

let name; console.log(name); // ? 

На экране появится undefined , специальное значение особого типа, которое означает отсутствие значения. Undefined активно используется самим JavaScript в самых разных ситуациях, например, при обращении к несуществующему символу строки:

const name = 'Arya'; console.log(name[8]); 

Смысл (семантика) значения undefined именно в том, что значения нет. Однако, ничто не мешает написать такой код:

let key = undefined; 

И хотя интерпретатор позволяет такое сделать, это нарушение семантики значения undefined , ведь в этом коде выполняется присваивание, а значит — подставляется значение.

JavaScript — один из немногих языков, в которых в явном виде присутствует понятие undefined . В остальных языках его роль выполняет значение null , которое, кстати, тоже есть в JavaScript.

Вопрос на самопроверку. Почему нельзя объявить константу без указания значения?

Ответ Константу невозможно изменить или переопределить. Ее значение необходимо указывать строго при определении.

Задание

Выведите на экран значение undefined , не указывая его явно (через присваивание или передав напрямую в console.log() ). Если не догадаетесь, как это сделать, подсмотрите решение учителя.

Упражнение не проходит проверку — что делать? ��

Если вы зашли в тупик, то самое время задать вопрос в «Обсуждениях». Как правильно задать вопрос:

  • Обязательно приложите вывод тестов, без него практически невозможно понять что не так, даже если вы покажете свой код. Программисты плохо исполняют код в голове, но по полученной ошибке почти всегда понятно, куда смотреть.

В моей среде код работает, а здесь нет ��

Тесты устроены таким образом, что они проверяют решение разными способами и на разных данных. Часто решение работает с одними входными данными, но не работает с другими. Чтобы разобраться с этим моментом, изучите вкладку «Тесты» и внимательно посмотрите на вывод ошибок, в котором есть подсказки.

Мой код отличается от решения учителя ��

Это нормально ��, в программировании одну задачу можно выполнить множеством способов. Если ваш код прошел проверку, то он соответствует условиям задачи.

В редких случаях бывает, что решение подогнано под тесты, но это видно сразу.

Прочитал урок — ничего не понятно ��

Создавать обучающие материалы, понятные для всех без исключения, довольно сложно. Мы очень стараемся, но всегда есть что улучшать. Если вы встретили материал, который вам непонятен, опишите проблему в «Обсуждениях». Идеально, если вы сформулируете непонятные моменты в виде вопросов. Обычно нам нужно несколько дней для внесения правок.

Кстати, вы тоже можете участвовать в улучшении курсов: внизу есть ссылка на исходный код уроков, который можно править прямо из браузера.

Полезное

Определения

  • undefined — аналог отсутствия значения; указывает, что переменной не присвоено значение или она вообще не объявлена.

const

Создаём переменную, значение которой нельзя изменить.

Время чтения: меньше 5 мин

Открыть/закрыть навигацию по статье

  1. Кратко
  2. Пример
  3. Как понять
    1. Зачем нужны константы?
    1. Николай Лопин советует
    1. В чём разница между null, undefined и объявленной переменной без начального значения? (let foo;)

    Контрибьюторы:

    Обновлено 10 апреля 2024

    Кратко

    Скопировать ссылку «Кратко» Скопировано

    const — ключевое слово языка для объявления констант. Константа — переменная, значение которой нельзя переназначить.

    Пример

    Скопировать ссылку «Пример» Скопировано

     const DAYS_IN_YEAR = 365 const DAYS_IN_YEAR = 365      

    Как понять

    Скопировать ссылку «Как понять» Скопировано

    Константы — те же переменные. Единственная разница в том, что их нельзя переопределить.

    Если попробовать это сделать, то код упадёт с ошибкой TypeError : invalid assignment to const :

     const DAYS_IN_YEAR = 365 console.log(DAYS_IN_YEAR) DAYS_IN_YEAR = 600// Ошибка, константы нельзя переопределять const DAYS_IN_YEAR = 365 console.log(DAYS_IN_YEAR) DAYS_IN_YEAR = 600 // Ошибка, константы нельзя переопределять      

    ошибка TypeError в консоли

    ☝️ Если константа хранит массив или объект, то сам массив/объект изменять можно! Нельзя заменить один объект на другой. Это происходит из-за того, что константа хранит ссылку на сложное значение, а не само значение.

    Например, мы можем добавить новый объект в массив, но при попытке записать в переменную series пустой массив произойдёт ошибка:

     const series = ['Доктор Хаус', 'Клиника', 'Чёрное зеркало']series.push('Молодой папа')series = []// ��‍♂️ не можем _заменить_ один массив на другой const series = ['Доктор Хаус', 'Клиника', 'Чёрное зеркало'] series.push('Молодой папа') series = [] // ��‍♂️ не можем _заменить_ один массив на другой      

    Та же история с объектами:

     const person = person.age = 0person = // ��‍♀️ не можем заменить на новый объект const person =  name: 'X Æ A-12', lastName: 'Musk' > person.age = 0 person =  name: 'Педро' > // ��‍♀️ не можем заменить на новый объект      

    Зачем нужны константы?

    Скопировать ссылку «Зачем нужны константы?» Скопировано

    Константы защищают код от случайной перезаписи важных значений.

    Применяют константы в двух случаях:

    • мы хотим объявить переменную, которая хранит фундаментальное значение для программы. Например, количество дней в году, минимальную сумму заказа, форматы дат и так далее.
    • мы объявляем переменную и устанавливаем ей значение всего один раз.

    Как пишется

    Скопировать ссылку «Как пишется» Скопировано

    Константы объявляются так же, как и переменные:

     const name = value const name = value     

    name Имя константы. Может использоваться любой допустимый идентификатор.

    value Значение константы. Любое допустимое выражение.

    На практике

    Скопировать ссылку «На практике» Скопировано

    Николай Лопин советует

    Скопировать ссылку «Николай Лопин советует» Скопировано

    �� Константы в современном JavaScript используют чаще, чем переменные. В большинстве случаев, значение переменной устанавливается только один раз. Хорошей практикой считается объявлять такие переменные через const и писать название переменной в camelCase, чтобы подчеркнуть этот факт:

     for (let i = 0; i < users.length; ++i)  const user = users[i] printUserInfo(user)> for (let i = 0; i  users.length; ++i)  const user = users[i] printUserInfo(user) >      

    �� Используйте ALL _ CAPS формат именования, если нужно объявить константу, которая хранит важное значение для программы: количество элементов на странице по умолчанию, формат даты, максимальное количество заказов и т. д.

     const ITEMS_PER_PAGE = 25 for (let i = 0; i < products.length && i < ITEMS_PER_PAGE; i++)  printItem(products[i])> const ITEMS_PER_PAGE = 25 for (let i = 0; i  products.length && i  ITEMS_PER_PAGE; i++)  printItem(products[i]) >      

    + Развернуть

    На собеседовании

    Скопировать ссылку «На собеседовании» Скопировано

    В чём разница между null , undefined и объявленной переменной без начального значения? ( let foo; )

    Скопировать ссылку «В чём разница между null, undefined и объявленной переменной без начального значения? (let foo;)» Скопировано

    Скопировать ссылку «Алекс Рассудихин отвечает» Скопировано

    null задаётся переменной явно и означает, что она является объектом, но структура этого объекта ещё не определена. undefined присваивается переменной (переменная не декларирует объект), когда она была объявлена, но не было определено её начальное значение. Функция может возвращать undefined или null . Всё зависит от того, что мы ожидаем в результате работы функции. Если мы ожидаем объект, но по каким-то причинам функция его вернуть не может, то возвращаем null . Если функция должна вернуть, например, число (главное, не объект), но не может этого сделать, то она возвращает undefined .

    Без начального значения можно оставлять только переменную, объявленную через let или var . Если объявить переменную через const и не задать ей начального значения, будет ошибка: Uncaught SyntaxError : Missing initializer in const declaration .

    Поговорим немного о приведении типов. Для начала, пример:

     console.log(null + null); // 0console.log(undefined + undefined); // NaN console.log(null + null); // 0 console.log(undefined + undefined); // NaN      
    • null во время сложения приводится к нулю;
    • undefined во время сложения приводится к NaN . NaN это аббревиатура от «not a number» — не число. Результат арифметической операции равен NaN , если во время операции произошла ошибка и ожидаемый числовой результат не может быть выражен числом.

    Есть ещё один хитрый пример:

     console.log(null + []); // "null" console.log(null + []); // "null"      

    Подсказка, почему так, кроется именно в типе результате: «null» — строка. А не примитивное значение null .

    JavaScript сначала приводит массив к примитивному значению. Для этого вызывается метод to String ( ) , который вызывает метод join ( ) . Т.к. массив пустой, то join ( ) вернёт пустую строку «» . А сложение чего-то со строкой в JS возвращает строку. Поэтому null уже никуда не приводится, а возращается строка «null» .

    Немного упомяну и про оператор нулевого слияния ( ? ? ). В выражении между двумя операндами он будет возвращать первый операнд, если он не равен null или undefined . Можно сказать, что ? ? приравнивает смысл undefined и null к «ничего не содержит», и, в этом случае, кладёт в переменную значение второго операнда.

    JavaScript: undefined

    Объявление переменных возможно и без указания конкретного значения. Что будет выведено на экран если её распечатать?

    let name; console.log(name); // ? 

    На экране появится undefined , специальное значение особого типа, которое означает отсутствие значения. Undefined активно используется самим JavaScript в самых разных ситуациях, например, при обращении к несуществующему символу строки:

    const name = 'Arya'; console.log(name[8]); 

    Смысл (семантика) значения undefined именно в том, что значения нет. Однако, ничто не мешает написать такой код:

    let key = undefined; 

    И хотя интерпретатор позволяет такое сделать, это нарушение семантики значения undefined , ведь в этом коде выполняется присваивание, а значит — подставляется значение.

    JavaScript — один из немногих языков, в которых в явном виде присутствует понятие undefined . В остальных языках его роль выполняет значение null , которое, кстати, тоже есть в JavaScript.

    Вопрос на самопроверку. Почему нельзя объявить константу без указания значения?

    Ответ Константу невозможно изменить или переопределить. Ее значение необходимо указывать строго при определении.

    Задание

    Выведите на экран значение undefined , не указывая его явно (через присваивание или передав напрямую в console.log() ). Если не догадаетесь, как это сделать, подсмотрите решение учителя.

    Упражнение не проходит проверку — что делать? ��

    Если вы зашли в тупик, то самое время задать вопрос в «Обсуждениях». Как правильно задать вопрос:

    • Обязательно приложите вывод тестов, без него практически невозможно понять что не так, даже если вы покажете свой код. Программисты плохо исполняют код в голове, но по полученной ошибке почти всегда понятно, куда смотреть.

    В моей среде код работает, а здесь нет ��

    Тесты устроены таким образом, что они проверяют решение разными способами и на разных данных. Часто решение работает с одними входными данными, но не работает с другими. Чтобы разобраться с этим моментом, изучите вкладку «Тесты» и внимательно посмотрите на вывод ошибок, в котором есть подсказки.

    Мой код отличается от решения учителя ��

    Это нормально ��, в программировании одну задачу можно выполнить множеством способов. Если ваш код прошел проверку, то он соответствует условиям задачи.

    В редких случаях бывает, что решение подогнано под тесты, но это видно сразу.

    Прочитал урок — ничего не понятно ��

    Создавать обучающие материалы, понятные для всех без исключения, довольно сложно. Мы очень стараемся, но всегда есть что улучшать. Если вы встретили материал, который вам непонятен, опишите проблему в «Обсуждениях». Идеально, если вы сформулируете непонятные моменты в виде вопросов. Обычно нам нужно несколько дней для внесения правок.

    Кстати, вы тоже можете участвовать в улучшении курсов: внизу есть ссылка на исходный код уроков, который можно править прямо из браузера.

    Полезное

    Определения

    • undefined — аналог отсутствия значения; указывает, что переменной не присвоено значение или она вообще не объявлена.

    const

    Значение констант не может быть изменено новым присваиванием, а также не может быть переопределено. Константы ( const ) подчиняются области видимости уровня блока так же, как переменные, объявленные с использованием ключевого слова let .

    Синтаксис

    const name1 = value1 [, name2 = value2 [, . [, nameN = valueN]]];

    Имя константы. Подчиняется тем же правилам, что и идентификаторы обычных переменных.

    Значение константы. Может быть любым из тех типов, которые могут быть для переменных, включая функцию.

    Описание

    Это объявление создаёт константу, чья область действия может быть как глобальной, так и локальной внутри блока, в котором она объявлена. Глобальные константы не становятся свойствами объекта window, в отличие от var -переменных. Инициализация константы обязательна; необходимо указать значение одновременно с объявлением (смысл в том, что потом это значение изменить уже нельзя).

    const создаёт константу (новую именованную ссылку на область памяти), доступную только для чтения. Это не означает, что указываемое значение неизменно, но это означает, что идентификатор не может быть переназначен. Например, если константа указывает на объект, то сам объект может быть изменён.

    Все соображения по поводу временных мёртвых зон, применимы и к let и к const .

    Имена констант не могут совпадать с именами функций или переменных той же области видимости.

    Примеры

    Ниже описаны примеры, демонстрирующие поведение const . Попробуйте их выполнить в простом JavaScript-редакторе или в консоли браузера.

    // Примечание: Идентификаторы констант могут быть объявлены как в верхнем, // так и в нижнем регистре. Но правилом хорошего тона является использование // верхнего регистра. // определим MY_FAV как константу и присвоим ей значение 7 const MY_FAV = 7; // данное присваивание выдаст ошибку - Uncaught TypeError: Assignment to constant variable. MY_FAV = 20; // напечатает 7 console.log("my favorite number is: " + MY_FAV); // попробуем переопределить константу, будет брошено исключение - Uncaught SyntaxError: Identifier 'MY_FAV' has already been declared const MY_FAV = 20; // имя MY_FAV зарезервировано константой выше, данная операция // выкинет исключение var MY_FAV = 20; // здесь также будет ошибка let MY_FAV = 20; // Важно отметить свойства области видимости уровня блока if (MY_FAV === 7)  // Всё нормально. Создать константу или переменную MY_FAV можно. // (работает так же как и let при объявлении в блоке переменных, которые не const) const MY_FAV = 20; // MY_FAV теперь 20 console.log("my favorite number is " + MY_FAV); // это попадёт в глобальный контекст и выдаст ошибку var MY_FAV = 20; > // MY_FAV все ещё имеет значение 7 console.log("my favorite number is " + MY_FAV); // Выдаст ошибку, потому что константа не инициализирована - Uncaught SyntaxError: Missing initializer in const declaration const FOO; // const также работает с объектами const MY_OBJECT = "key": "value">; // Попытка переопределить ссылку на объект вызовет исключение - Uncaught TypeError: Assignment to constant variable. MY_OBJECT = "OTHER_KEY": "value">; // но, свойства объекта (ключи) можно изменять MY_OBJECT.key = "otherValue"; // Используйте Object.freeze() для того, чтобы сделать объект неизменяемым // То же самое применимо к массивам const MY_ARRAY = []; // Например, можно добавлять элементы в массив MY_ARRAY.push("A"); // ["A"] // Но менять ссылку на объект массива нельзя. Это вызовет исключение - Uncaught TypeError: Assignment to constant variable MY_ARRAY = ["B"] 

    Спецификация

    Specification
    ECMAScript Language Specification
    # sec-let-and-const-declarations

    Совместимость с браузерами

    BCD tables only load in the browser

    Смотрите также

    • var
    • let
    • Константы в справочнике JavaScript

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *