HTML Diff
72 added 18 removed
Original 2026-01-01
Modified 2026-02-26
1 - <p>1</p>
1 + <p>Каррирование</p>
2 - <a>Введение</a><p>Знакомимся с курсом и проектом "Генератор HTML", который будет постепенно разрабатываться в течение всего курса</p>
2 + <p>частичное применение</p>
3 - <p>2</p>
3 + <p>Диспетчеризация</p>
4 - <a>Представление последовательностей</a><p>Вспоминаем пары (pairs) и рассматриваем представление списков с помощью пар</p>
4 + <p>ленивые вычисления</p>
5 - <p>3</p>
5 + <p>мемоизация</p>
6 - <a>Разметка</a><p>Начинаем разрабатывать библиотеку для работы с HTML, знакомимся с Markdown и изучаем общие принципы языков разметки на примере HTML</p>
6 + <p>Навык понимать программы на фундаментальном уровне, уверенно проходить собеседования и решать сложные задачи</p>
7 - <p>4</p>
7 + <p>Дмитрий Горохов</p>
8 - <a>Отображение списков</a><p>Рассматриваем функцию map и способ отображения списков</p>
8 + <p>выпускник пайтон</p>
9 - <p>5</p>
9 + <h2>Программа обучения</h2>
10 - <a>Фильтрация списков</a><p>Изучаем новую очень важную операцию - фильтрацию</p>
10 + <p>Guard Expression</p>
11 - <p>6</p>
11 + <p>Уменьшение сложности функций через разделение логики на условия</p>
12 - <a>Свертка</a><p>Рассматриваем третий столп функционального программирования - функцию reduce</p>
12 + <p>Параметры по умолчанию</p>
13 - <p>7</p>
13 + <p>Синтаксис задания параметров по умолчанию в функциях, влияние параметров по умолчанию на поведение функции при отсутствии аргументов, использование параметров по умолчанию для упрощения вызова функций</p>
14 - <a>Стандартные интерфейсы</a><p>Разбираемся в преимуществах хорошей абстракции и выясняем, как писать код так, чтобы его было легче комбинировать</p>
14 + <p>Выполнение функций</p>
15 - <p>8</p>
15 + <p>Порядок выполнения функций в составных выражениях</p>
16 - <a>Иерархические структуры</a><p>Переходим к построению иерархических структур с помощью пар</p>
16 + <p>Объекты первого класса</p>
17 - <p>9</p>
17 + <p>Понятие функций как объектов первого класса, передача функций в качестве аргументов другим функциям, возврат функций как результата выполнения других функций</p>
18 - <a>Уровневое проектирование</a><p>Знакомимся с уровневым проектированием на примере нашей реализации библиотеки для работы с HTML</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>
 
64 + </li>
 
65 + <li><p>Пожизненный доступ к теории</p>
 
66 + </li>
 
67 + <li><p>Обучение с ИИ-ассистентом</p>
 
68 + </li>
 
69 + <li><p>Отмена в любой момент</p>
 
70 + </li>
 
71 + </ul><h2>Нам доверяют обучение своих сотрудников</h2>
 
72 + <h2>Отзывы о Хекслете на площадках</h2>