--- title: class slug: Web/JavaScript/Reference/Statements/class tags: - ECMAScript 2015 - JavaScript - Довідка - Класи - оголошення translation_of: Web/JavaScript/Reference/Statements/class ---
Оголошення класу створює новий клас із заданим ім'ям, на основі прототипного наслідування.
Ви також можете визначити клас, використовуючи {{jsxref("Operators/class", "вираз класу", "", 1)}}. Але, на відміну від виразу класу, оголошення класу не дозволяє повторне оголошення існуючого класу і викине помилку при спробі це зробити.
class name [extends] {
// тіло класу
}
Тіло класу у оголошенні класу виконується у строгому режимі. Властивість constructor є необов'язковою.
Оголошення класу не {{Glossary("Hoisting", "виринають")}} (на відміну від оголошення функцій).
У наступному прикладі ми спочатку визначаємо клас на ім'я Polygon, далі розширюємо його, створюючи клас на ім'я Square. Зауважте, що ключове слово super() може використовуватись лише у конструкторах і має викликатись раніше, ніж використовується ключове слово this.
class Polygon {
constructor(height, width) {
this.name = 'Polygon';
this.height = height;
this.width = width;
}
}
class Square extends Polygon {
constructor(length) {
super(length, length);
this.name = 'Square';
}
}
Повторне оголошення класу викидає помилку типу.
class Foo {};
class Foo {}; // Uncaught SyntaxError: Identifier 'Foo' has already been declared
Така сама помилка викидається, коли клас був визначений до використання виразу класу.
var Foo = class {};
class Foo {}; // Uncaught TypeError: Identifier 'Foo' has already been declared
| Специфікація | Статус | Коментар |
|---|---|---|
| {{SpecName('ES2015', '#sec-class-definitions', 'Class definitions')}} | {{Spec2('ES2015')}} | Початкове визначення. |
| {{SpecName('ES2016', '#sec-class-definitions', 'Class definitions')}} | {{Spec2('ES2016')}} | |
| {{SpecName('ES2017', '#sec-class-definitions', 'Class definitions')}} | {{Spec2('ES2017')}} | |
| {{SpecName('ESDraft', '#sec-class-definitions', 'Class definitions')}} | {{Spec2('ESDraft')}} |
{{Compat("javascript.statements.class")}}