НАЙКРАЩИЙ САЙТ ДЛЯ ВЕБ-РОЗРОБНИКІВ

Базовий JavaScript

JS Підручник JS Синтаксис JS Змінні JS Оператори JS If Умови JS Цикли JS Рядки JS Числа JS Функції JS Об’єкти JS Дати JS Масиви JS Набори JS Карти JS Математичні JS RegExp JS Типи даних JS Помилки JS Дебагінг JS Події JS Програмування JS Довідники JS UTF-8 Характери

JS Розширений

JS Версії JS Функції JS Об’єкти JS Класи JS Ітерації JS Проміси JS Модулі JS HTML DOM JS Вікна JS Web API JS AJAX JS JSON JS jQuery JS Графіка JS Приклади JS Об’єкти

JavaScript. Уроки W3Schools для початківців українською мовою

En Es De Fr Ru

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 піднімаються вгору і можуть бути ініціалізовані у будь-який час.

Важливо: Ви можете використовувати змінну до оголошення:

Приклад

Це OK:

carName = "Volvo";
var carName;
Спробуйте самі »

Якщо ви хочете дізнатися більше про підйом (хостинг), вивчіть розділ JavaScript Хостинг на нашому сайті W3Schools українською.

Змінні, визначені за допомогою const також піднімаються вгору, але не ініціалізуються.

Важливо: використання змінної const перед її оголошенням призведе до помилки ReferenceError:

Приклад

alert (carName);
const carName = "Volvo";
Спробуйте самі »


Коментарі