aboutsummaryrefslogtreecommitdiff
path: root/files/uk/web/javascript/reference/classes/extends
diff options
context:
space:
mode:
authorPeter Bengtsson <mail@peterbe.com>2020-12-08 14:43:23 -0500
committerPeter Bengtsson <mail@peterbe.com>2020-12-08 14:43:23 -0500
commit218934fa2ed1c702a6d3923d2aa2cc6b43c48684 (patch)
treea9ef8ac1e1b8fe4207b6d64d3841bfb8990b6fd0 /files/uk/web/javascript/reference/classes/extends
parent074785cea106179cb3305637055ab0a009ca74f2 (diff)
downloadtranslated-content-218934fa2ed1c702a6d3923d2aa2cc6b43c48684.tar.gz
translated-content-218934fa2ed1c702a6d3923d2aa2cc6b43c48684.tar.bz2
translated-content-218934fa2ed1c702a6d3923d2aa2cc6b43c48684.zip
initial commit
Diffstat (limited to 'files/uk/web/javascript/reference/classes/extends')
-rw-r--r--files/uk/web/javascript/reference/classes/extends/index.html112
1 files changed, 112 insertions, 0 deletions
diff --git a/files/uk/web/javascript/reference/classes/extends/index.html b/files/uk/web/javascript/reference/classes/extends/index.html
new file mode 100644
index 0000000000..fb64cf21aa
--- /dev/null
+++ b/files/uk/web/javascript/reference/classes/extends/index.html
@@ -0,0 +1,112 @@
+---
+title: extends
+slug: Web/JavaScript/Reference/Classes/extends
+tags:
+ - ECMAScript 2015
+ - JavaScript
+ - Класи
+translation_of: Web/JavaScript/Reference/Classes/extends
+---
+<div>{{jsSidebar("Classes")}}</div>
+
+<p>Ключове слово <strong><code>extends</code></strong> використовується у <a href="/uk/docs/Web/JavaScript/Reference/Statements/class">оголошеннях класів</a> або у <a href="/uk/docs/Web/JavaScript/Reference/Operators/class">виразах класів</a> для створення дочірнього класу від іншого класу.</p>
+
+<div>{{EmbedInteractiveExample("pages/js/classes-extends.html", "taller")}}</div>
+
+
+
+<h2 id="Синтаксис">Синтаксис</h2>
+
+<pre class="syntaxbox">class ChildClass extends ParentClass { ... }</pre>
+
+<h2 id="Опис">Опис</h2>
+
+<p>Ключове слово <code>extends</code> може використовуватись для створення підкласів з користувацьких класів, як і з вбудованих об'єктів.</p>
+
+<p>Значенням <code>.prototype</code> батьківського класу має бути {{jsxref("Object")}} або {{jsxref("null")}}.</p>
+
+<h2 id="Приклади">Приклади</h2>
+
+<h3 id="Використання_extends">Використання <code>extends</code></h3>
+
+<p>Перший приклад створює клас на ім'я <code>Square</code> (квадрат) з класу на ім'я <code>Polygon</code> (багатокутник). Даний приклад взятий з цього <a href="https://googlechrome.github.io/samples/classes-es6/index.html">зразка </a><a href="https://github.com/GoogleChrome/samples/blob/gh-pages/classes-es6/index.html">(джерело)</a>.</p>
+
+<pre class="brush: js">class Square extends Polygon {
+ constructor(length) {
+ // Тут він викликає конструктор батьківського класу
+ // та надає значення ширини й довжини багатокутника
+ super(length, length);
+ // Заувага: У похідному класі super() має викликатися до
+ // використання 'this'. Інакше виникне помилка посилання.
+ this.name = 'Square';
+ }
+
+ get area() {
+ return this.height * this.width;
+ }
+}</pre>
+
+<h3 id="Використання_extends_із_вбудованими_обєктами">Використання <code>extends</code> із вбудованими об'єктами</h3>
+
+<p>Цей приклад розширює вбудований об'єкт {{jsxref("Date")}}. Даний приклад взяти з цього <a href="https://googlechrome.github.io/samples/classes-es6/index.html">зразка</a> <a href="https://github.com/GoogleChrome/samples/blob/gh-pages/classes-es6/index.html">(джерело)</a>.</p>
+
+<pre class="brush: js">class myDate extends Date {
+ constructor() {
+ super();
+ }
+
+ getFormattedDate() {
+ var months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'];
+ return this.getDate() + '-' + months[this.getMonth()] + '-' + this.getFullYear();
+ }
+}</pre>
+
+<h3 id="Розширення_null">Розширення <code>null</code></h3>
+
+<p>Розширення {{jsxref("null")}} працює, як для звичайних класів, за винятком того, що прототип не успадковується від {{jsxref("Object.prototype")}}.</p>
+
+<pre class="brush: js">class nullExtends extends null {
+ constructor() {}
+}
+
+Object.getPrototypeOf(nullExtends); // Function.prototype
+Object.getPrototypeOf(nullExtends.prototype) // null
+
+new nullExtends(); //ReferenceError: this is not defined
+</pre>
+
+<h2 id="Специфікації">Специфікації</h2>
+
+<table class="standard-table">
+ <tbody>
+ <tr>
+ <th scope="col">Специфікація</th>
+ <th scope="col">Статус</th>
+ <th scope="col">Коментар</th>
+ </tr>
+ <tr>
+ <td>{{SpecName('ES2015', '#sec-class-definitions', 'extends')}}</td>
+ <td>{{Spec2('ES2015')}}</td>
+ <td>Початкове визначення.</td>
+ </tr>
+ <tr>
+ <td>{{SpecName('ESDraft', '#sec-class-definitions', 'extends')}}</td>
+ <td>{{Spec2('ESDraft')}}</td>
+ <td></td>
+ </tr>
+ </tbody>
+</table>
+
+<h2 id="Сумісність_з_веб-переглядачами">Сумісність з веб-переглядачами</h2>
+
+
+
+<p>{{Compat("javascript.classes.extends")}}</p>
+
+<h2 id="Див._також">Див. також</h2>
+
+<ul>
+ <li><a href="/uk/docs/Web/JavaScript/Reference/Classes">Класи</a></li>
+ <li><a href="/uk/docs/Web/JavaScript/Reference/Operators/super">super</a></li>
+ <li><a href="https://medium.com/beginners-guide-to-mobile-web-development/super-and-extends-in-javascript-es6-understanding-the-tough-parts-6120372d3420">Anurag Majumdar - Super &amp; Extends in JavaScript</a></li>
+</ul>