generated from hexlet-basics/exercises-template
-
Notifications
You must be signed in to change notification settings - Fork 3
/
description.ru.yml
83 lines (58 loc) · 5.45 KB
/
description.ru.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
---
name: Создание (определение) функций
theory: |
Определение собственных функций значительно упрощает написание и поддержку программ. Функции позволяют объединять сложные (составные) операции в одну. Например, отправка письма на сайте - это достаточно сложный процесс, включающий в себя взаимодействие с внешними системами (интернет). Благодаря возможности определять функции, вся сложность может быть скрыта за одной простой функцией:
```javascript
// Гипотетический пример
// Место откуда берется функция
import { send } from 'mailer';
const email = 'support@hexlet.io';
const title = 'Помогите';
const body = 'Я написал историю успеха, как я могу получить скидку?';
// Один маленький вызов — и много логики внутри
send(email, title, body);
```
Внутри себя подобный вызов выполняет довольно много логики. Соединяется с почтовым сервером, формирует правильный запрос на основе заголовка и тела сообщения, а затем все это отправляет, не забыв закрыть соединение.
Создадим нашу первую функцию. Ее задача - вывести на экран приветствие:
<pre class='hexlet-basics-output'>Hello, Hexlet!</pre>
```javascript
// Определение функции
// Определение не вызывает и не выполняет функцию
// Мы лишь говорим, что теперь такая функция существует
const showGreeting = () => {
// Внутри тела отступ 2 пробела для удобства чтения
const text = 'Hello, Hexlet!';
console.log(text);
}
// Вызов функции
showGreeting(); // => Hello, Hexlet!
```
https://replit.com/@hexlet/js-basics-functions-define
В отличие от обычных данных, функции выполняют действия, поэтому их имена практически всегда должны быть глаголами: «построить что-то», «нарисовать что-то», «открыть что-то».
Всё, что описывается внутри фигурных скобок `{}`, называется телом функции. Внутри тела можно описывать любой код. Считайте, что это маленькая самостоятельная программа, набор произвольных инструкций. Тело выполняется ровно в тот момент, когда запускается функция. Причём каждый вызов функции запускает тело независимо от других вызовов. Кстати, тело может быть пустым:
```javascript
// Минимальное определение функции
const noop = () => {
// Тут мог бы быть код, но его нет
}
noop();
```
Определение функции подозрительно похоже на создание константы. Действительно, в реальности, определение функции состоит из двух частей: собственно определения и присваивания константе:
1. Определение: `() => { }`
2. Присваивание `const nameOfFunction = ...`
Технически возможно создать функцию, которая просто определена, но ей невозможно воспользоваться, потому что нет имени:
```javascript
() => {
// Работающий, но бесполезный код
};
```
Понятие «создать функцию» имеет много синонимов: «реализовать», «определить» и даже «заимплементить» (от слова implement). Все они встречаются в повседневной практике на работе.
instructions: |
Реализуйте функцию с именем `printMotto()`, которая выведет на экран фразу *Winter is coming*.
```javascript
printMotto(); // => Winter is coming
```
В задачах, в которых нужно реализовать функцию, эту функцию вызывать не нужно. Вызывать функцию будут автоматизированные тесты, которые проверяют её работоспособность. Пример с вызовом выше показан только для того, чтобы вы понимали, как ваша функция будет использоваться.
tips:
- |
[Именование в программировании](https://ru.hexlet.io/blog/posts/naming-in-programming)