JavaScript Ключове слово Const
Ключове слово const
було введено в ES6 (2015).
Змінні, визначені за допомогою const
не можуть бути повторно оголошені.
Змінні, визначені за допомогою const
не можна перепризначити.
Змінні, визначені за допомогою const
мають область дії блока.
Неможливо перепризначити
Змінну const
не можна перепризначити:
Приклад
const PI = 3.141592653589793;
PI = 3.14; // Це видасть помилку
PI = PI + 10; // Це також видасть помилку
Спробуйте самі »
Має бути призначено
JavaScript змінним const
має бути присвоєно значення при їх оголошенні.
Правильно
const PI = 3.14159265359;
Неправильно
const PI;
PI = 3.14159265359;
Коли використовувати JavaScript const?
Як правило, завжди оголошуйте змінні за допомогою const
, якщо ви не знаєте, що значення зміниться.
Завжди використовуйте const
під час оголошення:
- Новий масив
- Новий об’єкт
- Нова функція
- Новий RegExp
Постійні об'єкти та масиви
Ключове слово const
трохи вводить в оману.
Воно не визначає постійне значення. Це визначає постійне посилання на значення.
Через це ви НЕ МОЖЕТЕ:
- Перезначити постійне значення
- Перезначити постійний масив
- Перезначити постійний об'єкт
Але ви МОЖЕТЕ:
- Змінити постійний масив
- Змінити постійний об’єкт
Постійні масиви
Ви можете змінити елементи постійного масиву:
Приклад
// Ви можете створити постійний масив:
const cars = ["Saab", "Volvo", "BMW"];
// Ви можете змінити елемент:
cars[0] = "Toyota";
// Ви можете додати елемент:
cars.push("Audi");
Спробуйте самі »
Але ви не можете перепризначити масив:
Приклад
const cars = ["Saab", "Volvo", "BMW"];
cars = ["Toyota", "Volvo", "Audi"]; // ERROR (ПОМИЛКА)
Спробуйте самі »
Постійні об’єкти
Ви можете змінити властивості постійного об’єкту:
Приклад
// Ви можете створити об’єкт const:
const car = {type:"Fiat", model:"500", color:"white"};
// Ви можете змінити властивість:
car.color = "red";
// Ви можете додати властивість:
car.owner = "Johnson";
Спробуйте самі »
Але ви не можете перепризначити об’єкт:
Приклад
const car = {type:"Fiat", model:"500", color:"white"};
car = {type:"Volvo", model:"EX60", color:"red"}; // ERROR (ПОМИЛКА)
Спробуйте самі »
Підтримка браузерами
Ключове слово const
не підтримується в Internet Explorer 10 або раніших.
У наступній таблиці визначено перші версії браузера з повною підтримкою ключового слова const
:
Chrome 49 | IE 11 / Edge | Firefox 36 | Safari 10 | Opera 36 |
Mar, 2016 | Oct, 2013 | Feb, 2015 | Sep, 2016 | Mar, 2016 |
Область дії блоку
Оголошення змінної за допомогою const
аналогічно let
коли справа доходить Області дії блоку.
Змінна х, оголошена в блоці в цьому прикладі, не збігається зі змінною x, оголошеною поза блоком:
Приклад
const x = 10;
// Тут x дорівнює 10
{
const x = 2;
// Тут x дорівнює 2
}
// Тут x дорівнює 10
Спробуйте самі »
Ви можете дізнатися більше про область дії блоку в розділі JavaScript Область дії.
Повторне оголошення
Повторне оголошення JavaScript змінної var
дозволено в будь-якому місці програми:
Приклад
var x = 2; // Дозволено
var x = 3; // Дозволено
x = 4; // Дозволено
Повторне оголошення існуючої змінної var
або let
на const
у тій самій області не дозволено:
Приклад
var x = 2; // Дозволено
const x = 2; // Не дозволено
{
let x = 2; // Дозволено
const x = 2; // Не дозволено
}
{
const x = 2; // Дозволено
const x = 2; // Не дозволено
}
Перепризначення існуючої змінної const
у тій самій області дії не дозволено:
Приклад
const x = 2; // Дозволено
x = 2; // Не дозволено
var x = 2; // Не дозволено
let x = 2; // Не дозволено
const x = 2; // Не дозволено
{
const x = 2; // Дозволено
x = 2;
// Не дозволено
var x = 2;
// Не дозволено
let x = 2;
// Не дозволено
const x = 2; // Не разрешено
}
Дозволено повторне оголошення змінної за допомогою const
в іншій області дії або в іншому блоці:
Приклад
const x = 2; // Дозволено
{
const x = 3; // Дозволено
}
{
const x = 4; // Дозволено
}
Підйом (хостинг) Const
Змінні, визначені за допомогою var
піднімаються вгору і можуть бути ініціалізовані у будь-який час.
Важливо: Ви можете використовувати змінну до оголошення:
Якщо ви хочете дізнатися більше про підйом, вивчіть розділ JavaScript Підйом на нашому сайті W3Schools українською.
Змінні, визначені за допомогою const
також піднімаються вгору, але не ініціалізуються.
Важливо: використання змінної const
перед її оголошенням призведе до помилки ReferenceError
: