HTML Diff
68 added 40 removed
Original 2026-01-01
Modified 2026-02-26
1 - <p>рекурсивные структуры данных</p>
1 + <p>Каррирование</p>
2 - <p>обход в глубину</p>
2 + <p>частичное применение</p>
3 - <p>древовидная рекурсия</p>
3 + <p>Диспетчеризация</p>
4 - <p>файловая система</p>
4 + <p>ленивые вычисления</p>
5 - <p>Последнее обновление: 24 декабря 2025 г.</p>
5 + <p>мемоизация</p>
6 - <p>Включено в курс</p>
6 + <p>Навык понимать программы на фундаментальном уровне, уверенно проходить собеседования и решать сложные задачи</p>
7 - <p>9 уроков (видео и/или текст)</p>
7 + <p>Дмитрий Горохов</p>
8 - <h2>Описание</h2>
8 + <p>выпускник пайтон</p>
9 - <p>На этом курсе вы изучите работу с деревьями в JavaScript. Вы узнаете о рекурсивных структурах данных, обходе в глубину и древовидной рекурсии. В итоге вы разберетесь, как деревья устроены изнутри. Эти знания пригодятся при работе с категориями товаров, комментариями, HTML, XML, JSON.</p>
9 + <h2>Программа обучения</h2>
10 - <h2>Чему вы научитесь</h2>
10 + <p>Guard Expression</p>
11 - <ul><li><p>Разбираться в принципах работы с деревьями</p>
11 + <p>Уменьшение сложности функций через разделение логики на условия</p>
 
12 + <p>Параметры по умолчанию</p>
 
13 + <p>Синтаксис задания параметров по умолчанию в функциях, влияние параметров по умолчанию на поведение функции при отсутствии аргументов, использование параметров по умолчанию для упрощения вызова функций</p>
 
14 + <p>Выполнение функций</p>
 
15 + <p>Порядок выполнения функций в составных выражениях</p>
 
16 + <p>Объекты первого класса</p>
 
17 + <p>Понятие функций как объектов первого класса, передача функций в качестве аргументов другим функциям, возврат функций как результата выполнения других функций</p>
 
18 + <p>Лексическое окружение</p>
 
19 + <p>Понятие лексического окружения и его роль в работе замыканий, взаимосвязь между лексическим окружением и областью видимости</p>
 
20 + <p>Частичное применение и каррирование</p>
 
21 + <p>Техника частичного применения для фиксации части аргументов функции, понятие каррирования и его преимущества для создания специализированных функций, сравнение частичного применения и каррирования в реальных сценариях</p>
 
22 + <p>Моделирование предметной области</p>
 
23 + <p>Создание моделей предметной области для представления данных и отношений, использование моделей для создания абстракций и сокрытия деталей реализации</p>
 
24 + <p>Барьеры абстракции</p>
 
25 + <p>Понятие барьеров абстракции и их роль в разделении уровней системы, примеры повышения уровня абстракции для упрощения взаимодействия между компонентами, влияние барьеров абстракции на поддерживаемость и расширяемость кода</p>
 
26 + <p>Составные данные</p>
 
27 + <p>Создание составных данных для представления сложных структур данных, использование составных данных для создания эффективного и масштабируемого кода</p>
 
28 + <p>Пары</p>
 
29 + <p>Создание пар и других составных данных для представления отношений между данными, использование пар и других составных данных для создания модульного и гибкого кода</p>
 
30 + <p>Рациональные числа</p>
 
31 + <p>Представление рациональных чисел как абстракции на основе пар, реализация операций над рациональными числами,</p>
 
32 + <p>Моделирование сложных систем</p>
 
33 + <p>Представление сложных структур данных на базе более простых, создание последовательностей на основе пар, обработка последовательностей</p>
 
34 + <p>Инверсия</p>
 
35 + <p>Изучение принципа инверсии зависимостей и его применение для улучшения тестируемости</p>
 
36 + <p>Помеченные данные</p>
 
37 + <p>Изучение концепции помеченных данных и их роли в управлении состоянием программы</p>
 
38 + <p>Диспетчеризация по типу и аддитивность</p>
 
39 + <p>Понятие аддитивных программ и их преимущества для построения модульных систем, изучение механизма динамической диспетчеризации и его роли в управлении поведением программы</p>
 
40 + <p>Объекты</p>
 
41 + <p>Основные принципы работы с объектами в контексте ООП, роль динамической диспетчеризации в работе с объектами и их методами, создание и использование объектов</p>
 
42 + <p>Нативные объекты</p>
 
43 + <p>Изучение объектов, встроенных в JavaScript, таких как Object, Array, Date и других, разбор особенностей изменяемости объектов, даже если они объявлены как константы, работа с нативными объектами</p>
 
44 + <p>Классы и полиморфизм</p>
 
45 + <p>Классы как структуры для создания объектов, механизм создания объектов с помощью new, изучение понятия полиморфизма и его трех типов: параметрического, ad-hoc и подтипов, примеры использования полиморфизма для создания гибкой и расширяемой системы</p>
 
46 + <p>Массивы</p>
 
47 + <p>Основные операции с массивами: добавление, удаление, поиск. особенности работы с массивами в JavaScript, примеры использования массивов для хранения и обработки данных</p>
 
48 + <p>Map и Set</p>
 
49 + <p>Структура данных Map для хранения пар ключ-значение, структура данных Set для хранения уникальных значений</p>
 
50 + <p>Fluent Interface</p>
 
51 + <p>Паттерн Fluent Interface для создания цепочек вызовов методов, примеры реализации Fluent Interface в JavaScript, преимущества и недостатки использования Fluent Interface</p>
 
52 + <p>Неизменяемость</p>
 
53 + <p>Понятие неизменяемости и её роль в функциональном программировании, примеры использования неизменяемых структур данных, влияние неизменяемости на производительность и безопасность кода</p>
 
54 + <p>Ленивые вычисления</p>
 
55 + <p>Понятие ленивых вычислений и их применение в JavaScript, примеры использования ленивых вычислений для оптимизации работы с коллекциями, сравнение ленивых и строгих вычислений</p>
 
56 + <p>Операции rest, spread и деструктуризация</p>
 
57 + <p>Операция rest для работы с переменным количеством аргументов, операция spread для объединения и копирования данных, деструктуризация массивов и объектов для извлечения данных</p>
 
58 + <h2>Как проходит обучение</h2>
 
59 + <p>Теория в удобном текстовом формате - легко читать даже с телефона. Живые примеры помогают понять, как всё работает. Материал выстроен так, чтобы вы двигались шаг за шагом, не упуская важных деталей</p>
 
60 + <p>Подписка от 2 400 ₽/мес</p>
 
61 + <p>Этот навык уже входит в подписку. Оформи доступ и открывай все навыки сразу (50+)</p>
 
62 + <p><a>Подписаться →</a></p>
 
63 + <ul><li><p>50+ навыков в одной подписке</p>
12 </li>
64 </li>
13 - <li><p>Представлять и обрабатывать данные с рекурсивной природой - например, файловые системы, каталоги или деревья комментариев</p>
65 + <li><p>Пожизненный доступ к теории</p>
14 </li>
66 </li>
15 - <li><p>Строить абстракции поверх древовидных структур данных</p>
67 + <li><p>Обучение с ИИ-ассистентом</p>
16 </li>
68 </li>
17 - <li><p>Использовать функциональную парадигму</p>
69 + <li><p>Отмена в любой момент</p>
18 </li>
70 </li>
19 - </ul><h2>Формат обучения</h2>
71 + </ul><h2>Нам доверяют обучение своих сотрудников</h2>
20 - <h2>Испытания</h2>
72 + <h2>Отзывы о Хекслете на площадках</h2>
21 - <p>1</p>
 
22 - <p>Выравнивание (Массив)</p>
 
23 - <p>2</p>
 
24 - <p>Отслеживание зависимостей</p>
 
25 - <p>3</p>
 
26 - <p>JSON stringify</p>
 
27 - <p>4</p>
 
28 - <p>Построение маршрута</p>
 
29 - <p>5</p>
 
30 - <p>Пазл</p>
 
31 - <p>6</p>
 
32 - <p>Массив как объект</p>
 
33 - <p>7</p>
 
34 - <p>Отображение, фильтрация, свёртка</p>
 
35 - <p>8</p>
 
36 - <p>Трансформер</p>
 
37 - <h2>Рекомендуемые программы</h2>
 
38 - <ul><li><p>Тренажер с практикой</p>
 
39 - </li>
 
40 - <li><p>Бессрочный доступ к теории</p>
 
41 - </li>
 
42 - <li><p>Асинхронный формат</p>
 
43 - </li>
 
44 - </ul>