diff options
Diffstat (limited to 'files/ru/web/javascript/reference/classes/static/index.html')
-rw-r--r-- | files/ru/web/javascript/reference/classes/static/index.html | 129 |
1 files changed, 129 insertions, 0 deletions
diff --git a/files/ru/web/javascript/reference/classes/static/index.html b/files/ru/web/javascript/reference/classes/static/index.html new file mode 100644 index 0000000000..cec6516733 --- /dev/null +++ b/files/ru/web/javascript/reference/classes/static/index.html @@ -0,0 +1,129 @@ +--- +title: static +slug: Web/JavaScript/Reference/Classes/static +translation_of: Web/JavaScript/Reference/Classes/static +--- +<div>{{jsSidebar("Classes")}}</div> + +<p>Для того, чтобы объявить статический метод класса, необходимо использовать ключевое слово <strong>static</strong>.</p> + +<h2 id="Синтаксис">Синтаксис</h2> + +<pre class="syntaxbox">static <em>methodName</em>() { ... }</pre> + +<h2 id="Описание">Описание</h2> + +<p>Cтатические методы вызываются через имя класса. Вызывать статические методы через имя объекта запрещено. Статические методы часто используются для создания вспомогательных функций приложения.</p> + +<h2 id="Вызов_статических_методов">Вызов статических методов</h2> + +<h3 id="Вызов_из_другого_статического_метода">Вызов из другого статического метода</h3> + +<p>Чтобы вызвать статический метод в другом статическом методе того же класса, вы можете использовать ключевое слово <code><a href="/ru/docs/Web/JavaScript/Reference/Operators/this">this</a></code>.</p> + +<pre class="brush: js">class StaticMethodCall { + static staticMethod() { + return 'Вызван статический метод'; + } + static anotherStaticMethod() { + return this.staticMethod() + ' из другого статического метода'; + } +} +StaticMethodCall.staticMethod(); +// 'Вызван статический метод' + +StaticMethodCall.anotherStaticMethod(); +// 'Вызван статический метод из другого статического метода' +</pre> + +<h3 id="Вызов_из_конструктора_класса_и_других_методов">Вызов из конструктора класса и других методов</h3> + +<p>Статические методы недоступны напрямую, используя ключевое слово <code><a href="/ru/docs/Web/JavaScript/Reference/Operators/this">this</a></code> из нестатических методов. Вам нужно вызвать их с помощью имени класса: <code>CLASSNAME.STATIC_METHOD_NAME()</code> или вызовом метода как свойства конструктора: <code>this.constructor.STATIC_METHOD_NAME()</code>.</p> + +<pre class="brush: js">class StaticMethodCall { + constructor() { + console.log(StaticMethodCall.staticMethod()); + // 'вызван статический метод.' + + console.log(this.constructor.staticMethod()); + // 'вызван статический метод.' + } + + static staticMethod() { + return 'вызван статический метод.'; + } +}</pre> + +<h2 id="Примеры">Примеры</h2> + +<p>Следующий пример демонстрирует:</p> + +<ol> + <li>Как статический метод реализуется в классе.</li> + <li>Как переопределить статический метод при наследовании.</li> + <li>Как можно и как нельзя вызывать статические методы.</li> +</ol> + +<pre class="brush: js">class Triple { + static triple(n) { + if (n === undefined) { + n = 1; + } + return n * 3; + } +} + +class BiggerTriple extends Triple { + static triple(n) { + return super.triple(n) * super.triple(n); + } +} + +console.log(Triple.triple()); // 3 +console.log(Triple.triple(6)); // 18 + +var tp = new Triple(); + +console.log(BiggerTriple.triple(3)); +// 81 (не затрагивается экземпляром родителя) + +console.log(tp.triple()); +// Выведет сообщение, что "tripple" не является +// функцией ('tp.tripple is not a function'). +</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', 'Class definitions')}}</td> + <td>{{Spec2('ES2015')}}</td> + <td>Изначальное определение</td> + </tr> + <tr> + <td>{{SpecName('ESDraft', '#sec-class-definitions', 'Class definitions')}}</td> + <td>{{Spec2('ESDraft')}}</td> + <td> </td> + </tr> + </tbody> +</table> + +<h2 id="Поддержка_в_браузерах">Поддержка в браузерах</h2> + +<div class="hidden">Таблица совместимости на этой странице создается из структурированных данных. Если вы хотите внести свой вклад в данные, ознакомьтесь с <a href="https://github.com/mdn/browser-compat-data">https://github.com/mdn/browser-compat-data</a> и отправить нам запрос на слияние.</div> + +<p>{{Compat("javascript.classes.static")}}</p> + +<h2 id="Смотрите_также">Смотрите также</h2> + +<ul> + <li><a href="/ru/docs/Web/JavaScript/Reference/Operators/class"><code>class</code> expression</a></li> + <li><a href="/ru/docs/Web/JavaScript/Reference/Statements/class"><code>class</code> declaration</a></li> + <li><a href="/ru/docs/Web/JavaScript/Reference/Classes">Classes</a></li> +</ul> |