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:
