diff options
Diffstat (limited to 'files/uk/web/javascript/reference/statements/function/index.html')
-rw-r--r-- | files/uk/web/javascript/reference/statements/function/index.html | 179 |
1 files changed, 179 insertions, 0 deletions
diff --git a/files/uk/web/javascript/reference/statements/function/index.html b/files/uk/web/javascript/reference/statements/function/index.html new file mode 100644 index 0000000000..c038ec106d --- /dev/null +++ b/files/uk/web/javascript/reference/statements/function/index.html @@ -0,0 +1,179 @@ +--- +title: Оголошення функції +slug: Web/JavaScript/Reference/Statements/function +tags: + - JavaScript + - Функція +translation_of: Web/JavaScript/Reference/Statements/function +--- +<div>{{jsSidebar("Statements")}}</div> + +<p><strong>Оголошення функції</strong> (функціональний оператор) визначає функцію з вказаними параметрами.</p> + +<p>Ви також можете визначати функції за допомогою конструктора {{jsxref("Function")}} та {{jsxref("Operators/function", "функціонального виразу")}}.</p> + +<div>{{EmbedInteractiveExample("pages/js/statement-function.html")}}</div> + + + +<h2 id="Синтаксис">Синтаксис</h2> + +<pre class="syntaxbox">function <em>name</em>([<em>param</em>[, <em>param</em>,[..., <em>param</em>]]]) { + [<em>statements</em>] +} +</pre> + +<dl> + <dt><code>name</code></dt> + <dd>Ім'я функції.</dd> +</dl> + +<dl> + <dt><code>param</code></dt> + <dd>Ім'я аргументу, що передається у функцію. Максимальна кількість аргументів відрізняється у різних рушіях.</dd> +</dl> + +<dl> + <dt><code>statements</code></dt> + <dd>Інструкції, які складають тіло функції.</dd> +</dl> + +<h2 id="Опис">Опис</h2> + +<p>Функція, утворена через оголошення функції, є об'єктом <code>Function</code>, і має усі властивості, методи та поведінку об'єктів <code>Function</code>. Більш детальну інформацію щодо функцій дивіться у статті {{jsxref("Function")}}.</p> + +<p>Функція також може бути створена через за допомогою виразу (дивіться {{jsxref("Operators/function", "функціональний вираз")}}).</p> + +<p>За замовчуванням функції повертають <code>undefined</code>. Щоб повернути будь-яке інше значення, функція повинна мати оператор {{jsxref("Statements/return", "return")}}, який вказує значення, що буде повернене.</p> + +<h3 id="Умовне_створення_функцій">Умовне створення функцій</h3> + +<p>Функції можуть оголошуватися за певної умови, тобто, оголошення функції може бути вкладене у <code>if</code>, однак, результат різниться між реалізаціями, тому цей шаблон не варто використовувати у виробничому коді. Для умовного створення функції використовуйте, натомість, функціональний вираз.</p> + +<pre class="brush: js">var hoisted = "foo" in this; +console.log(`Ім'я 'foo'${hoisted ? "" : " не"} піднімається. typeof foo дорівнює ${typeof foo}`); +if (false) { + function foo(){ return 1; } +} + +// У Chrome: +// Ім'я 'foo' піднімається. typeof foo дорівнює undefined +// +// У Firefox: +// Ім'я 'foo' піднімається. typeof foo дорівнює undefined +// +// У Edge: +// Ім'я 'foo' не піднімається. typeof foo дорівнює undefined +// +// У Safari: +// Ім'я 'foo' піднімається. typeof foo дорівнює function +</pre> + +<p>Результат буде такий самий для умови, яка дорівнює true</p> + +<pre class="brush: js">var hoisted = "foo" in this; +console.log(`Ім'я 'foo' ${hoisted ? "" : " не"} піднімається. typeof foo дорівнює ${typeof foo}`); +if (true) { + function foo(){ return 1; } +} + +// У Chrome: +// Ім'я 'foo' піднімається. typeof foo дорівнює undefined +// +// У Firefox: +// Ім'я 'foo' піднімається. typeof foo дорівнює undefined +// +// У Edge: +// Ім'я 'foo' не піднімається. typeof foo дорівнює undefined +// +// У Safari: +// Ім'я 'foo' піднімається. typeof foo дорівнює function +</pre> + +<h3 id="Підняття_оголошення_функції">Підняття оголошення функції</h3> + +<p>Оголошення функцій у JavaScript піднімаються наверх замикаючої функції або глобальної області видимості. Ви можете використовувати функцію до того, як оголосили її:</p> + +<pre class="brush: js">hoisted(); // виводить "foo" + +function hoisted() { + console.log('foo'); +} +</pre> + +<p>Зауважте, що {{jsxref("Operators/function", "функціональні вирази")}} не піднімаються:</p> + +<pre class="brush: js">notHoisted(); // TypeError: notHoisted is not a function + +var notHoisted = function() { + console.log('bar'); +}; +</pre> + +<h2 id="Приклади">Приклади</h2> + +<h3 id="Використання_function">Використання <code>function</code></h3> + +<p>Наступний код оголошує функцію, яка повертає загальну суму продажів, отримуючи кількість одиниць продуктів <code>a</code>, <code>b</code> та <code>c</code>.</p> + +<pre class="brush: js">function calc_sales(units_a, units_b, units_c) { + return units_a * 79 + units_b * 129 + units_c * 699; +} +</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('ESDraft', '#sec-function-definitions', 'Function definitions')}}</td> + <td>{{Spec2('ESDraft')}}</td> + <td></td> + </tr> + <tr> + <td>{{SpecName('ES6', '#sec-function-definitions', 'Function definitions')}}</td> + <td>{{Spec2('ES6')}}</td> + <td></td> + </tr> + <tr> + <td>{{SpecName('ES5.1', '#sec-13', 'Function definition')}}</td> + <td>{{Spec2('ES5.1')}}</td> + <td></td> + </tr> + <tr> + <td>{{SpecName('ES3', '#sec-13', 'Function definition')}}</td> + <td>{{Spec2('ES3')}}</td> + <td></td> + </tr> + <tr> + <td>{{SpecName('ES1', '#sec-13', 'Function definition')}}</td> + <td>{{Spec2('ES1')}}</td> + <td>Початкове визначення. Реалізоване у JavaScript 1.0.</td> + </tr> + </tbody> +</table> + +<h2 id="Сумісність_з_веб-переглядачами">Сумісність з веб-переглядачами</h2> + + + +<p>{{Compat("javascript.statements.function")}}</p> + +<h2 id="Див._також">Див. також</h2> + +<ul> + <li>{{jsxref("Functions", "Функції")}}</li> + <li>{{jsxref("Function")}}</li> + <li>{{jsxref("Operators/function", "функціональний вираз")}}</li> + <li>{{jsxref("Statements/function*", "оператор function*")}}</li> + <li>{{jsxref("Operators/function*", "вираз function*")}}</li> + <li>{{jsxref("Functions/Стрілкові_функції", "Стрілкові функції")}}</li> + <li>{{jsxref("GeneratorFunction")}}</li> + <li>{{jsxref("Statements/async_function", "async function")}}</li> + <li>{{jsxref("Operators/async_function", "вираз async function")}}</li> +</ul> |