--- 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")}}