Курсы и вебинары JavaScript в Специалисте
JavaScript-разработка
Веб-программирование
Почти 100% современных сайтов интерактивны. Фотогалереи, окна подписки, слайдеры, меню, оповещения, анимация – эти элементы «оживляют» сайт и делают его более удобным для пользователя. За интерактив с посетителем на интернет-ресурсе отвечает JavaScript — сценарный язык программирования. На нем прописывают, как должен реагировать сайт на каждое действие пользователя.
Появившись в середине 90-х, JavaScript сразу захватил мир. Мода на динамические сайты сделала этот скриптовый язык, встроенный по умолчанию во все браузеры, самым распространенным в мире. В рейтинге популярности языков программирования аналитической компании RedMonk, составленном в 2016 году, JavaScript занимает 1-е место.
Несколько фактов о JavaScript
- JavaScript идеально подходит в качестве первого языка программирования, если вы планируете развиваться в веб-разработке.
- Язык прост в изучении, а писать код на нем можно в любом текстовом редакторе.
- Знание JavaScript – самое частое требование в вакансиях веб-разработчиков.
- Изучив JavaScript, можно развиваться в серверном программировании Node.js.
- После изучения JavaScript вам будет легче освоить С#, С++, Java, PHP, поскольку они имеют похожий синтаксис.
- Ваша продуктивность в разработке вырастет, если использовать библиотеки jQuery, React и Angular2.
Квалифицированные веб-разработчики, способные создавать динамические веб-страницы, на рынке труда в цене. Если вы решили развиваться в области веб-разработки, начните с профессиональных курсов JavaScript в учебном центре «Специалист»!
Преподаватели «Специалиста» – сертифицированные разработчики с большим практическим опытом, успешно запустившие не один веб-проект. Под их руководством вы узнаете многочисленные тонкости разработки на JavaScript, научитесь создавать интерфейсы и веб-приложения, познакомитесь с частыми проблемами и способами их решения.
На занятиях упор делается на практическое применение возможностей JavaScript для ваших проектов.Центр «Специалист» при МГТУ им. Н.Э. Баумана имеет лицензию на образовательную деятельность и работает с 1991 года. Наши свидетельства и дипломы высоко ценятся на рынке труда. Среди преимуществ курсов JavaScript в «Специалисте» — возможность учиться в разных форматах (очно, очно-заочно, в режиме онлайн), расписание на год вперед, гарантия 100%-го качества обучения, классы с современными компьютерами и бесплатные кофе-брейки.
Курсы JavaScript в «Специалисте» — начало успешной карьеры веб-разработчика!
-
22.03.2023
Другие даты
Дипломная программа — 336 ак.ч
Веб — программист. Профессиональная разработка на PHP и JS
Продолжительность: от 4 до 8 месяцев
Один курс в подарок!
Гревцов
Валентин
Валентинович
Читать отзывы
189 290 ₽
252 410 ₽
213 590 ₽
284 910 ₽
% Доступно в рассрочку и кредит
-
16.
03.2023Другие даты
Дипломная программа — 370 ак.ч
Фуллстек — разработчик на JavaScript
Продолжительность: от 4 до 8 месяцев
Один курс в подарок!
Шуйков
Сергей
Юрьевич
Читать отзывы
207 290 ₽
276 390 ₽
241 790 ₽
322 390 ₽
% Доступно в рассрочку и кредит
-
Другие даты
Дипломная программа — 438 ак. ч
Фронтенд — разработчик на React
Продолжительность: от 4 до 8 месяцев
Один курс в подарок!
Шуйков
Сергей
Юрьевич
Читать отзывы
232 390 ₽
309 880 ₽
266 890 ₽
355 880 ₽
% Доступно в рассрочку и кредит
-
16.03.2023
Другие даты
Дипломная программа — 432 ак.ч
Фронтенд — разработчик на Vue.
jsПродолжительность: от 4 до 8 месяцев
Один курс в подарок!
Шуйков
Сергей
Юрьевич
Читать отзывы
233 890 ₽
311 880 ₽
266 490 ₽
355 380 ₽
% Доступно в рассрочку и кредит
-
16.03.2023
Другие даты
Дипломная программа — 278 ак.ч
JavaScript — разработчик
Продолжительность: от 3 до 6 месяцев
Один курс в подарок!
Шуйков
Сергей
Юрьевич
Читать отзывы
155 890 ₽
207 920 ₽
179 990 ₽
240 420 ₽
% Доступно в рассрочку и кредит
-
16. 03.2023
Другие даты
Дипломная программа — 536 ак.ч
Фуллстек Голанг — разработчик
Продолжительность: от 4 до 8 месяцев
Один курс в подарок!
Шуйков
Сергей
Юрьевич
Читать отзывы
262 390 ₽
349 880 ₽
294 590 ₽
392 880 ₽
% Доступно в рассрочку и кредит
-
Другие даты
Дипломная программа — 274 ак. ч
Фронтенд — разработчик
Продолжительность: от 3 до 6 месяцев
Один курс в подарок!
Гревцов
Валентин
Валентинович
Читать отзывы
129 290 ₽
172 430 ₽
149 490 ₽
199 430 ₽
% Доступно в рассрочку и кредит
-
Звоните по тел.
+7 (495) 232-32-16Дипломная программа — 292 ак.ч
Профессиональный веб — разработчик на Laravel и React
Продолжительность: от 3 до 6 месяцев
Один курс в подарок!
179 190 ₽
238 920 ₽
203 890 ₽
271 920 ₽
% Доступно в рассрочку и кредит
-
12. 03.2023
Другие даты
Комплексная программа — 92 ак.ч
Специалист JavaScript
Вы экономите 22% стоимости второго курса!
Тарасов
Алексей
Владимирович
Читать отзывы
45 390 ₽
53 480 ₽
52 590 ₽
61 980 ₽
-
12.03.2023
Другие даты
Комплексная программа — 254 ак.ч
Фуллстек JavaScript — разработчик
Один курс в подарок!
Тарасов
Алексей
Владимирович
Читать отзывы
159 290 ₽
187 430 ₽
185 590 ₽
218 430 ₽
-
12. 03.2023
Другие даты
Комплексная программа — 224 ак.ч
Эксперт по программированию на JavaScript (со знанием Vue.js и Node.js)
Один курс в подарок!
Тарасов
Алексей
Владимирович
Читать отзывы
141 890 ₽
166 940 ₽
164 790 ₽
193 940 ₽
-
12.03.2023
Другие даты
Комплексная программа — 122 ак.ч
Фреймворки JavaScript
Вы экономите 66% стоимости четвёртого курса!
Тарасов
Алексей
Владимирович
Читать отзывы
79 790 ₽
93 960 ₽
88 290 ₽
103 960 ₽
-
12. 03.2023
Другие даты
Курс — 26 ак.ч
JavaScript. Уровень 6. Библиотека React.js
Тарасов
Алексей
Владимирович
Читать отзывы
19 490 ₽
22 990 ₽
-
12.03.2023
Другие даты
Курс — 32 ак.ч
JavaScript.
Уровень 1. Основы JavaScriptТарасов
Алексей
Владимирович
Читать отзывы
15 990 ₽
21 490 ₽
-
12.03.2023
Другие даты
Курс — 20 ак.ч
JavaScript. Уровень 3. ESNext
Тарасов
Алексей
Владимирович
Читать отзывы
21 490 ₽
25 490 ₽
-
20. 03.2023
Другие даты
Курс — 60 ак.ч
JavaScript. Уровень 2. Расширенные возможности
Тарасов
Алексей
Владимирович
Читать отзывы
37 490 ₽
40 490 ₽
-
12.03.2023
Другие даты
Курс — 36 ак.ч
JavaScript.
Уровень 7. Redux и react — routerТарасов
Алексей
Владимирович
Читать отзывы
26 990 ₽
31 490 ₽
-
19.05.2023
Другие даты
Курс — 36 ак.ч
JavaScript. Уровень 8. Vue.js – открытый фреймворк на JavaScript для разработки веб — приложений
Цымбалов
Сергей
Николаевич
Читать отзывы
26 990 ₽
29 990 ₽
-
18. 12.2023
Другие даты
Курс — 24 ак.ч
JavaScript. Уровень 9. Vue.js. Расширенные возможности
Цымбалов
Сергей
Николаевич
Читать отзывы
21 490 ₽
23 990 ₽
-
12.03.2023
Другие даты
Курс — 24 ак.ч
Практика создания веб — приложения (фронтенд)
Тарасов
Алексей
Владимирович
Читать отзывы
19 490 ₽
22 990 ₽
-
12. 03.2023
Другие даты
Курс — 36 ак.ч
JavaScript. Уровень 4. Fetch/AJAX API
Тарасов
Алексей
Владимирович
Читать отзывы
32 490 ₽
38 990 ₽
-
12.03.2023
Другие даты
Курс — 36 ак.ч
JavaScript.
Уровень 5. Серверное программирование на Node.jsТарасов
Алексей
Владимирович
Читать отзывы
32 490 ₽
38 990 ₽
-
12.03.2023
Другие даты
Курс — 36 ак.ч
JavaScript. Уровень 10. HTML5 API
Тарасов
Алексей
Владимирович
Читать отзывы
29 990 ₽
32 490 ₽
-
19. 08.2023
Другие даты
Курс — 16 ак.ч
Введение в TypeScript
Гревцов
Валентин
Валентинович
Читать отзывы
12 490 ₽
14 990 ₽
-
13.03.2023
Другие даты
Курс — 52 ак.ч
Курс 20480C: Программирование в HTML5 с JavaScript и CSS3
Шуйков
Сергей
Юрьевич
Читать отзывы
42 990 ₽
47 490 ₽
-
13. 03.2023
Другие даты
Курс — 36 ак.ч
Разработка веб — приложений на AngularJS
Шуйков
Сергей
Юрьевич
Читать отзывы
25 990 ₽
26 990 ₽
JavaScript — Прототипно-ориентированный язык программирования / Хабр
Прототипно-ориентированный язык программирования
Статьи Авторы Компании
Сначала показывать
Порог рейтинга
Уровень сложности
000Z» title=»2023-03-11, 22:21″>4 минуты назад
Время на прочтение 9 мин
Количество просмотров39
JavaScript *ReactJS *TypeScript *HTML *
Мнение
Микрофронтенд-архитектура — это подход к созданию приложений, в котором каждая часть приложения, отвечающая за определенную функциональность, представлена отдельным фронтенд-приложением. Такой подход позволяет достичь более высокой гибкости и масштабируемости приложения, так как каждый микрофронтенд может быть разработан и развернут независимо от остальных.
Как правило, микрофронтенды используются в комбинации с микросервисной архитектурой, в которой приложение состоит из набора независимых микросервисов, каждый из которых выполняет свою функцию. Микрофронтенды позволяют разработчикам разрабатывать интерфейсы для каждого микросервиса отдельно и объединять их в единое приложение, что облегчает поддержку, масштабирование и развертывание приложения.
Одним из ключевых преимуществ микрофронтендов является возможность быстрой разработки и доставки изменений пользовательского интерфейса без необходимости изменения всего приложения. Кроме того, микрофронтенды могут помочь упростить процесс разработки, улучшить переиспользуемость кода и уменьшить зависимость между различными частями фронтенд-приложения.
Полезная ссылка с подробным объяснением концепции микрофронтенда.
Читать далее
Рейтинг 0
Комментарии 0
SumarokovVladimirУровень сложности Средний
Время на прочтение 4 мин
Количество просмотров3.6K
Разработка веб-сайтов *JavaScript *TypeScript *
Из песочницы
Сказ о том, как я каррирование типизировал
Читать далее
Всего голосов 10: ↑10 и ↓0 +10
Комментарии 2
qmzikУровень сложности Простой
Время на прочтение 3 мин
Количество просмотров4. 7K
CSS *JavaScript *Google Chrome HTML *Браузеры
Обзор
Перевод
Давайте погрузимся внутрь и посмотрим, что нового ждет разработчиков в Chrome 111.
Читать далее
Всего голосов 10: ↑10 и ↓0 +10
Комментарии 0
mishquaУровень сложности Средний
Время на прочтение 13 мин
Количество просмотров1K
Блог компании Bimeister Разработка веб-сайтов *JavaScript *Angular *TypeScript *
Туториал
Angular CDK имеет широкие возможности для скроллинга плоского списка. Если размер каждого элемента одинаков, то можно воспользоваться FixedSizeVirtualScrollStrategy
: всего лишь нужно прокинуть размер элемента в пикселях, проитерироваться по данным и виртуальный скроллинг готов. Но что делать, если размер элементов разный? Данную проблему можно решить кастомной стратегией виртуального скроллинга. В данной статье мы рассмотрим как построить такую стратегию для pdf-документов.
Читать далее
Всего голосов 14: ↑13 и ↓1 +12
Комментарии 0
igorg599Уровень сложности Средний
Время на прочтение 4 мин
Количество просмотров2.9K
JavaScript *Google Chrome Google API *Расширения для браузеров
Из песочницы
В данной статье рассмотрим создание расширения google chrome для записи экрана и камеры. Оно может записывать целый экран, отдельное окно или вкладку. В режиме записи экрана можно вставлять окно с фронтальной камерой внутрь страницы на которой активен плагин, либо вне браузера. Также можно включить запись микрофона или звук системы. Ну и дополнительно можно осуществлять запись только с камеры.
Читать далее
Всего голосов 15: ↑14 и ↓1 +13
Комментарии 8
FrontendProductionВремя на прочтение 4 мин
Количество просмотров1.8K
JavaScript *TypeScript *
Из песочницы
Когда вы только начинаете изучать веб-разработку, перед вами не стоит проблема сборщиков кода, но как только ваши приложения начинают разрастаться и разделяться на модули, встает вопрос о сборке кода. Любой разработчик знаком с Webpack, потому что на данный момент это номер один инструмент по популярности для сборки проектов, а с Rollup знакомы далеко не все.
Читать далее
Всего голосов 12: ↑6 и ↓6 0
Комментарии 4
aio350000Z» title=»2023-03-07, 11:01″>7 мар в 11:01
Уровень сложности Средний
Время на прочтение 34 мин
Количество просмотров1.1K
Блог компании Timeweb Cloud Разработка веб-сайтов *JavaScript *ReactJS *TypeScript *
Привет, друзья!
В этой серии статей я продолжаю рассказывать о Remix — новом фреймворке для создания клиент-серверных веб-приложений на JavaScript (React) со встроенной поддержкой TypeScript.
Remix позволяет разрабатывать так называемые PESPA (Progressive Enhancement Single Page Apps — одностраничные приложения с возможностью прогрессивного улучшения). Это означает следующее:
- почти весь код приложения «живет» на сервере;
- приложение остается функциональным даже при отсутствии JS;
- JS используется только для прогрессивного улучшения UX (User Experience — пользовательский опыт).
Подробнее о PESPA и других архитектурах веб-приложений можно почитать здесь.
Очевидно, что разработчики Remix вдохновлялись Next.js и Svelte.
К слову, здесь вы найдете полное руководство по Next.js.
В первой части мы прошлись по руководствам из официальной документации, во второй — более подробно рассмотрим возможности, предоставляемые Remix.
Это часть номер два.
Вот ссылка на часть номер раз.
Читать дальше →
Всего голосов 10: ↑10 и ↓0 +10
Комментарии 3
SergeiShaikinВремя на прочтение 8 мин
Количество просмотров878
Блог компании OTUS JavaScript *Тестирование веб-сервисов *ReactJS *
Перевод
Взгляд на популярную Testing Library с Nightwatch
Мы создадим подробный пример проекта React с Vite, а затем воспользуемся Nightwatch и Testing Library для тестирования этих компонентов. Мы используем Complex example, доступный в документах React Testing Library, написанный с помощью Jest.
Читать далее
Всего голосов 8: ↑8 и ↓0 +8
Комментарии 2
aio350Уровень сложности Средний
Время на прочтение 6 мин
Количество просмотров2.3K
Блог компании Timeweb Cloud JavaScript *Расширения для браузеров ReactJS *TypeScript *
Туториал
Hello, world!
В этом небольшом туториале мы с вами разработаем простое, но полезное расширение для браузера с помощью Plasmo.
Наше расширение будет представлять собой вызываемый сочетанием клавиш попап с инпутом для поиска информации на MDN с выводом 5 лучших результатов в виде списка. Кроме основного функционала, мы добавим страницу настроек для кастомизации цветов и отображения хлебных крошек. Мы будем разрабатывать расширения для Chrome, которое также будет работать в Firefox.
Вот как это будет выглядеть:
Для тех, кого интересует только код, вот ссылка на соответствующий репозиторий.
Интересно? Тогда прошу под кат.
Читать дальше →
Всего голосов 11: ↑11 и ↓0 +11
Комментарии 0
HAGer2000Время на прочтение 6 мин
Количество просмотров3.6K
JavaScript *Проектирование и рефакторинг *VueJS *TypeScript *
В большом vue-приложении всегда есть необходимость в декомпозиции компонентов и их логики. В статье приводятся размышления и некоторые выводы относительно подходов к декомпозиции vue-компонентов и их интерфейсу.
Читать далее
Всего голосов 4: ↑4 и ↓0 +4
Комментарии 1
EdgarAbgaryan000Z» title=»2023-03-06, 06:35″>6 мар в 06:35
Время на прочтение 32 мин
Количество просмотров3.5K
JavaScript *
Туториал
Фраза “делать свой велосипед” обычно употребляется для негативного окраса чего-то. Но именно этим мы будем заниматься здесь. Потому что это эффективный метод для того, чтобы разобраться в какой-то теме. Попробовав самому реализовать что-то, мы лучше разберемся в инструментах, которые обычно делают эту работу за нас. После этого мы сможем извлекать больше пользы из привычных инструментов. Например знания о внутреннем устройстве определённых систем позволит вам дебажить проблему гораздо быстрее хотя бы потому, что вы будете знать, что могло пойти не так. После того, как попытаешься реализовать что-то сам, некоторые вещи оказываются проще и перестают быть магией. А некоторые, казавшиеся простыми библиотеки, оказываются настолько пропитанными нюансами, что ты становишься благодарен создателю пакета за его труд
Читать далее
Всего голосов 10: ↑10 и ↓0 +10
Комментарии 15
rastvl000Z» title=»2023-03-05, 23:53″>5 мар в 23:53
Уровень сложности Средний
Время на прочтение 47 мин
Количество просмотров9.1K
JavaScript *Node.JS *Реверс-инжиниринг *
Akamai Technologies — американская компания, занимающаяся защитой веб-ресурсов от ботов с помощью своего продукта Bot Manager. В её портфолио числятся такие гиганты ритейла, как Nike, Adidas и Asos, для которых особенно важен контроль за ботами, автоматизирующими процесс выкупа редких/лимитированных товаров с целью их перепродажи по завышенной цене. В данной статье мы взглянем на скрипт антибота Akamai и рассмотрим, какие методы обнаружения через JavaScript в нём используются. Не знаете почему обнаруживается ваш selenium? Добро пожаловать!
Читать далее
Всего голосов 96: ↑96 и ↓0 +96
Комментарии 34
BoumRZ000Z» title=»2023-03-05, 18:58″>5 мар в 18:58
Уровень сложности Средний
Время на прочтение 11 мин
Количество просмотров2.9K
Разработка веб-сайтов *JavaScript *HTML *ReactJS *
Туториал
Из песочницы
В последнее время только ленивый не говорил про такую технологию, как module federation, было сделано огромное количество докладов, и наша команда, наслушавшись и насмотревшись, как это прекрасно, тоже решила затащить MF к себе в проект.
Однако, почти все доклады на эту тему не показывают серьезность проблем, с которыми можно столкнуться на пути.
В этой статье будет рассказано вкратце, для тех, кто ещё не знает, что такое module federation, в каких ситуациях его стоит использовать, как настроить продакшен сборку, а не только локальную, ну и какие проблемы вас могут ждать.
Начнем!
Читать далее
Всего голосов 9: ↑9 и ↓0 +9
Комментарии 20
0a1a2a3a4a5000Z» title=»2023-03-03, 20:28″>3 мар в 20:28
Уровень сложности Простой
Время на прочтение 9 мин
Количество просмотров12K
Python *JavaScript *Искусственный интеллект Будущее здесь Natural Language Processing *
Из песочницы
Не так давно мне в голову пришла идея воспользоваться моделью text-davinci-003 от OpenAI чтобы сгенерировать диалог между двумя языками программирования так, если бы они были реальными людьми. Я выбрал Javascript и Python.
Для этого я подготовил следующую инструкцию…
Читать далее
Всего голосов 14: ↑6 и ↓8 -2
Комментарии 12
IskorkinУровень сложности Средний
Время на прочтение 5 мин
Количество просмотров7. 2K
Веб-дизайн *JavaScript *Программирование *Работа с векторной графикой *HTML *
Из песочницы
Представьте, в вашем проекте есть куча разбросанных по пространству логически связанных элементов, которые (о ужас!) могут свободно перемещаться по пространству. Задача — красиво и наглядно показать пользователю эти связи, чтобы упорядочить представление. В данной статье я покажу нашу реализацию.
Читать далее
Всего голосов 34: ↑34 и ↓0 +34
Комментарии 11
aio350Уровень сложности Сложный
Время на прочтение 7 мин
Количество просмотров2K
Блог компании Timeweb Cloud Разработка веб-сайтов *JavaScript *ReactJS *TypeScript *
Обзор
Перевод
Hello, world!
Представляю вашему вниманию перевод этой замечательной статьи.
useSyncExternalStore — это один из хуков, представленных в React 18. Наряду с хуком useInsertionEffect, он считается хуком для библиотек (library hook):
Следующие хуки предназначены для авторов библиотек для глубокой интеграции библиотек в модель React. Как правило, они не используются в коде приложения
В списке изменений React 18 речь также идет о библиотеках:
Добавлен useSyncExternalStore
для помощи в интеграции с React библиотек внешних хранилищ (external store libraries)
Читать дальше →
Всего голосов 14: ↑14 и ↓0 +14
Комментарии 1
seooutstaffУровень сложности Простой
Время на прочтение 8 мин
Количество просмотров2.5K
PHP *JavaScript *Поисковая оптимизация *
Из песочницы
Подготовил подробную инструкцию, как сделать SEO-friendly сайт и учесть все основные SEO-требования на этапе разработки сайта.
Это статья очень важна, так как соблюдение SEO-требований на этапе создания нового сайта позволяет сэкономить много денег и времени на внесении дополнительных правок.
Ниже представлена подробная инструкция с основными SEO-требования, которые необходимо предусмотреть на этапе создания нового сайта.
Посмотреть Чек-лист
Всего голосов 7: ↑2 и ↓5 -3
Комментарии 8
felix_friendsВремя на прочтение 11 мин
Количество просмотров6.4K
JavaScript *ООП *ReactJS *
Перевод
Привет! Меня зовут Айнур, и я frontend-разработчик SimbirSoft. Более 6 лет я работаю над коммерческими проектами, создаю и улучшаю интерфейсы, поэтому в работе достаточно часто использую паттерны проектирования. Неоднократно я обращался за идеями и лайфхаками к книге Patterns. dev, которая содержит очень современный взгляд на шаблоны проектирования, рендеринга и производительности JavaScript.
Авторы Patterns.dev:
Лидия Холли — штатный консультант и преподаватель по разработке программного обеспечения, которая в основном работает с JavaScript, React, Node, GraphQL. Она также занимается наставничеством и проводит личные тренинги.
Эдди Османи — технический менеджер, работающий над Google Chrome. Его команды работают над такими проектами, как Lighthouse, PageSpeed Insights, Chrome User Experience Report и другими.
Материал книги будет полезен не только React-разработчикам, но и всем, кто так или иначе интересуется или сталкивается с frontend-разработкой.
В этом посте я публикую свой перевод первой из трех частей книги. В ней речь идет о множестве различных паттернов, которые включает в себя современная веб-разработка. Если материал будет вам полезен и получит положительный отклик, то я опубликую перевод следующей части.
Источник: https://www. patterns.dev/
Данный адаптированный материал распространяется на условиях лицензии Creative Commons Attribution-NonCommercial 4.0 International (CC BY-NC 4.0)
Читать далее
Всего голосов 7: ↑6 и ↓1 +5
Комментарии 3
VahmanУровень сложности Средний
Время на прочтение 4 мин
Количество просмотров1K
JavaScript *Angular *TypeScript *
Разработчики angular, как правило знают, что для работы с формами существует два подхода: reactive forms и template driven forms. Также, хорошо известно, что для работы с формами разработан такой функционал как валидация, однако исчерпывающе описано его применения для подхода reactive forms. Давайте рассмотрим как можно получить те же преимущества для template driven подхода.
Читать далее
Всего голосов 1: ↑1 и ↓0 +1
Комментарии 4
nmgtechУровень сложности Средний
Время на прочтение 8 мин
Количество просмотров4.3K
Блог компании Национальная Медиа Группа CSS *JavaScript *Работа с векторной графикой *Математика *
Туториал
Перевод
Сегодня я расскажу о процессе, который я придумал для преобразования SVG‑контура в векторный рисунок верёвки.
Вы узнаете, как превратить показанный слева контур в верёвку справа:
Эта задача возникла в проекте, над которым работали мои коллеги, и она привлекла моё внимание. Я думал о ней и начинал экспериментировать, как только появлялось свободное время. Это было очень увлекательно, поэтому я захотел поделиться с вами процессом решения.
Стоит учесть, что это не туториал по кодингу, а подробный обзор каждого из этапов. Но не беспокойтесь, код полностью доступен.
Замысел
Взглянув на это фото верёвки, вы заметите, что она состоит из множества переплетённых друг с другом прядей. Визуально они делят верёвку на сегменты. 2D‑проекция каждого сегмента напоминает изогнутый многоугольник.
Наша задача будет заключаться в создании этих многоугольников при помощи JavaScript.
Читать далее
Всего голосов 58: ↑57 и ↓1 +56
Комментарии 1
Учебник по современному JavaScript
Мы хотим сделать этот проект с открытым исходным кодом доступным для людей во всем мире.
Помогите перевести содержание этого руководства на ваш язык!
КупитьEPUB/PDF
Как это делается сейчас. От основ до продвинутых тем с простыми, но подробными объяснениями.
Последнее обновление 10 марта 2023 г.
BuyEPUB/PDF
Поделиться:
20256 ★github Discord Chat
Содержание
Основной курс состоит из 2 частей, посвященных JavaScript как языку программирования и работе с браузером. Также есть дополнительные серии тематических статей.
Язык JavaScript
Здесь мы изучаем JavaScript, начиная с нуля и переходя к продвинутым концепциям, таким как ООП.
Здесь мы концентрируемся на самом языке с минимумом примечаний, относящихся к среде.
Введение
Введение в JavaScript
Руководства и спецификации
Редакторы кода
Консоль разработчика
Основы JavaScript
Структура кода
Современный режим, «Использование строгих»
Переменные
Типы данных
Взаимодействие: Альтер, Подтверждение, Подтверждение
9003 9000 2 9002 9000 2 9003 9000 2 9003 9000 2 9003 9000 2 9003.0003Базовые операторы, математика
Сравнения
Условное ветвление: if, ‘?’
Логические операторы
Нулевой объединяющий оператор ‘??’
петли: в то время как и для
Оператор «Switch»
Функции
Функциональные выражения
Функции стрелки, базовые
Эрро0033
JavaScript specials
- More…
3 Привет, мир!
Code quality
Debugging in the browser
Coding Style
Comments
Ninja code
Automated testing with Mocha
Полифиллы и транспайлеры
Объекты: основы
Объекты
Ссылки на объекты и копирование
Сборка мусора
Методы объекта, «this»
Конструктор, оператор «new»
Необязательная цепочка ‘?. ‘
Symbol type
Object to primitive conversion
Data types
Methods of primitives
Numbers
Strings
Arrays
Array methods
Iterables
Map and Set
WeakMap and WeakSet
Object.keys, values, entries
Destructuring assignment
Date and time
Методы JSON, toJSON
- Подробнее…
Расширенная работа с функциями
Рекурсия и стек
Остаточные параметры и синтаксис распространения
Variable scope, closure
The old «var»
Global object
Function object, NFE
The «new Function» syntax
Scheduling: setTimeout and setInterval
Декораторы и переадресация, call/apply
Привязка функций
Пересмотр функций стрелок
- Подробнее…
Object properties configuration
Property flags and descriptors
Property getters and setters
Prototypes, inheritance
Prototypal inheritance
F. prototype
Native prototypes
Методы-прототипы, объекты без __proto__
Классы
Базовый синтаксис класса
Class inheritance
Static properties and methods
Private and protected properties and methods
Extending built-in classes
Class checking: «instanceof»
Mixins
Обработка ошибок
Обработка ошибок, «try…catch»
Пользовательские ошибки, расширение ошибки
Promises, async/await
Introduction: callbacks
Promise
Promises chaining
Error handling with promises
Promise API
Promisification
Microtasks
Async/await
Генераторы, расширенная итерация
Генераторы
Асинхронная итерация и генераторы
Modules
Modules, introduction
Export and Import
Dynamic imports
Miscellaneous
Proxy and Reflect
Eval: run a code string
Каррирование
Тип ссылки
BigInt
Unicode, String Internals
Браузер: документ, события, интерфейсы
Обучение управлению страницей браузера: добавление элементов, управление их размером и положением, динамическое создание интерфейсов и взаимодействие с посетителем.
Документ
Среда браузера, спецификации
DOM Tree
Ходячие DOM
Искреть: GetElement*, Queryselector*
.
Атрибуты и свойства
Modifying the document
Styles and classes
Element size and scrolling
Window sizes and scrolling
Coordinates
- More…
Introduction to Events
Знакомство с событиями браузера
Воспроизведение и захват
Делегирование событий
Действия браузера по умолчанию
Рассылка на заказ соревнования
Events
События мыши
Движение мыши: Mouseover/Out, MouseEnter/Leave
9936- 9000
. События указателя
Клавиатура: нажатие и нажатие
Прокрутка
Формы, элементы управления
Свойства и методы форм
Фокусировка: Focus/Blur
События: изменение, вход, вырезание, копия, вставка
Формы: Событие и метод Отправить
Документирование и загрузка ресурса
Page: Domcontentduded, загрузка. , beforeunload, unload
Скрипты: асинхронный, отложенный
Загрузка ресурсов: onload и onerror
Разное
0 Мутация наблюдателя 30036
Выбор и диапазон
Цикл событий: микрозадачи и макрозадачи
Дополнительные статьи
Список дополнительных тем, которые предполагают, что вы рассмотрели первые две части руководства. Здесь нет четкой иерархии, вы можете читать статьи в том порядке, в котором хотите.
Фреймы и окна
Всплывающие окна и методы окон
Межоконные коммуникации
Атака кликджекинга
Binary data, files
ArrayBuffer, binary arrays
TextDecoder and TextEncoder
Blob
File and FileReader
Network requests
Fetch
FormData
Извлечение: Ход загрузки
Извлечение: Прерывание
Извлечение: Запросы между источниками
Fetch API
URL objects
XMLHttpRequest
Resumable file upload
Long polling
WebSocket
Server Sent Events
- More…
Storing данные в браузере
Cookies, document. cookie
LocalStorage, sessionStorage
IndexedDB
Animation
Bezier curve
CSS-animations
JavaScript animations
Web components
From the orbital height
Custom elements
Shadow DOM
Элемент шаблона
Слоты Shadow DOM, композиция
Стиль Shadow DOM
9$, флаг «m»Граница слова: \b
Экранирование, специальные символы
Наборы и диапазоны […]
Квантификаторы +, *, Квантификаторы? и {n}
Жадные и ленивые квантификаторы
Группы захвата
Обратные ссылки в шаблоне: \N и \k
- Чередование (ИЛИ) |
Просмотр вперед и назад
Катастрофическая переходная обработка
Sticky Flag «Y», поиск по позиции
Методы реки REGEXP и строки
- More…
Gellaisplair 2
Deliporial 9000. 1000 2
. 9003
Deliporial Map 9003
9
. чистый сайт! Этот учебник по JavaScript поможет вам быстро и эффективно изучить язык программирования JavaScript с нуля.
Если вы…
- Не знаете, с чего начать изучение JavaScript.
- Недовольны копированием и вставкой кода JavaScript от других, не понимая его по-настоящему.
- Невозможно добавить более богатые и привлекательные функции на ваши веб-сайты и веб-приложения с помощью JavaScript, потому что вы не знаете, как извлечь большую пользу из языка.
JavaScriptTutorial.net — хорошее место для начала.
Раздел 2. Основы
- Синтаксис. Объясните синтаксис JavaScript, включая пробелы, операторы, идентификаторы, ключевые слова, выражения и комментарии.
- Переменные — покажет вам, как объявлять переменные.
- Типы данных — познакомьте вас с типами данных JavaScript, включая примитивные и ссылочные типы.
- Number — узнайте, как JavaScript использует тип
Number
для представления целых чисел и чисел с плавающей запятой. - Числовой разделитель — покажет вам, как сделать числа более читабельными, используя символы подчеркивания в качестве числовых разделителей.
- Восьмеричные и двоичные литералы — обеспечивают поддержку двоичных литералов и изменяют способ представления восьмеричных литералов.
- Boolean — познакомить вас с типом
Boolean
. - Строка — узнайте о примитивном типе строк и некоторых основных операциях со строками.
- Объект — познакомить вас с типом объекта.
- Примитивные и ссылочные значения. Понимание двух типов значений в JavaScript, включая примитивные и ссылочные значения, и различий между ними.
- Массив — познакомит вас с типом
Массив
и с тем, как манипулировать элементами массива.
Раздел 3. Операторы
- Арифметические операторы – познакомим вас с арифметическими операторами, включая сложение (
+
), вычитание (-
), умножение (*
) и деление (/
). - Оператор остатка — покажите, как использовать оператор остатка (
%
), чтобы получить остаток, оставшийся после деления одного значения на другое значение. - Операторы присваивания — руководство по использованию операторов присваивания (
=
), чтобы присвоить значение или выражение переменной. - Унарные операторы — узнайте, как использовать унарные операторы.
- Операторы сравнения — показано, как использовать операторы сравнения для сравнения двух значений.
- Логические операторы — научитесь использовать логические операторы: НЕ (
!
), И (&&
) и ИЛИ (||
). - Логические операторы присваивания — познакомить вас с логическими операторами присваивания, включая
||=
,&&=
и??=
- Нулевой оператор объединения (
??
) – принимает два значения и возвращает второе значение, если первоеnull
илиundefined
. - Оператор возведения в степень — познакомьте вас с оператором возведения в степень (
**
), который вычисляет основание степени экспоненты, что аналогично методуMath.pow()
.
- if — показать вам, как использовать оператор
if
для выполнения блока, если условие истинно. - if…else — научиться выполнять блок кода на основе заданного условия.
- if…else…if — проверить несколько условий и выполнить блок.
- Тернарные операторы — покажите, как сделать ярлык для оператора
if
(?:
). Переключатель - — показано, как заменить несколько операторов
if
при сравнении значения с несколькими вариантами с помощью оператораswitch
. - while — узнайте, как выполнить цикл предварительного тестирования, который многократно выполняет блок кода, пока заданное условие равно
правда
. - do…while — показать вам, как выполнять посттестовый цикл, который многократно выполняет блок кода до тех пор, пока заданное условие не станет
ложным
. - цикл for — узнайте, как многократно выполнять блок кода на основе различных параметров.
- break — узнайте, как досрочно завершить цикл.
- продолжить — показать, как пропустить текущую итерацию цикла и перейти к следующей.
- Оператор запятой — руководство по использованию оператора запятой в
для цикла
для одновременного обновления нескольких переменных.
Раздел 5. Функции
- Функции — познакомим вас с функциями в JavaScript.
- Функции являются гражданами первого класса — научитесь хранить функции в переменных, передавать функции в другие функции в качестве аргументов и возвращать функции в качестве значений.
- Анонимные функции — узнайте об анонимных функциях, то есть функциях без имен.
- Передача по значению — узнайте, как работает передача по значению в JavaScript.
- Рекурсивная функция — узнайте, как определять рекурсивные функции.
- Параметры по умолчанию — показывает, как определить параметры по умолчанию для функций.
Раздел 6. Объекты и прототипы
- Методы объекта — познакомит вас с методами объекта.
- Функции-конструкторы — покажут, как использовать функции-конструкторы для определения пользовательских типов в JavaScript.
- Прототип — узнайте, как прототип работает в JavaScript.
- Шаблон конструктора/прототипа — показывает, как объединить функцию конструктора и шаблон прототипа для определения пользовательских типов.
- Наследование прототипов — понимание наследования прототипов в JavaScript.
- Что это такое в JavaScript — узнайте, что такое
это значение
и как оно работает в JavaScript. - globalThis — стандартный способ доступа к глобальному объекту в разных средах.
- Свойства объекта — погрузитесь в свойства объекта и их атрибуты.
- цикл for…in — узнайте, как перебирать свойства объекта с помощью цикла
for…in
. - Перечислимые свойства — узнайте больше о перечисляемых свойствах.
- Собственные свойства — понимание собственных и унаследованных свойств.
- Object.values() – возвращает собственные перечисляемые значения свойств объекта в виде массива.
- Object.entries() – возвращает собственное перечислимое свойство со строковым ключом
[ключ, значение]
пар объекта. - Object.assign() – скопировать объект или объединить объекты.
- Object.is() — проверить, являются ли два значения одинаковыми.
- Фабричные функции — узнайте о фабричных функциях, которые возвращают объекты.
- Деструктуризация объектов — узнайте, как присваивать свойства объекта переменным.
- Необязательный оператор цепочки (
?.
) — упрощает доступ к свойству, расположенному глубоко внутри цепочки связанных объектов, без необходимости проверять, является ли каждая ссылка в цепочкеnull
илиundefined
. - Расширения синтаксиса литерала объекта — обеспечивают новый способ определения литерала объекта.
Раздел 7. Классы
- Класс — познакомит вас с синтаксисом класса ES6 и с тем, как объявить класс.
- Геттеры и сеттеры — определите геттеры и сеттеры для класса с помощью ключевых слов get и set.
- Выражение класса — изучите альтернативный способ определения нового класса с помощью выражения класса.
- Вычисляемое свойство – объяснить вычисляемое свойство и его практическое применение.
- Наследование — показать вам, как расширить класс с помощью
расширяет ключевые слова
иsuper
. - new.target — познакомить вас с метасвойством
new.target
. - Статические методы — руководство по определению методов, связанных с классом, а не с экземплярами этого класса.
- Статические свойства — показать вам, как определить статические свойства, общие для всех экземпляров класса.
- Частные поля — узнайте, как определять частные поля в классе.
- Частные методы — показать вам, как определить частные методы в классе.
Раздел 8. Дополнительные функции
- Тип функции — познакомить вас с типом
Функция
, его свойствами и методами. - call() — понять метод
call()
и научиться эффективно его использовать. - apply() — узнайте, как эффективно использовать метод
apply()
. - bind() — понимание метода
bind()
и способов его эффективного применения. - Замыкание — понимание замыканий в JavaScript.
- Немедленно вызываемое функциональное выражение (IIFE) — узнайте о немедленно вызываемых функциональных выражениях (IIFE).
- Возврат нескольких значений — руководство по возврату нескольких значений из функции.
- Функции стрелок – познакомьте вас с функциями стрелок (
=>
) - Функции стрелок: когда не следует использовать – узнайте, когда не следует использовать функции стрелок.
- Параметр остатка — познакомит вас с параметром остатка и с тем, как его эффективно использовать.
- Функции обратного вызова — познакомьте вас с функциями обратного вызова и узнайте, как использовать обратные вызовы для обработки асинхронных операций.
Раздел 9. Промисы и Async/Await
- Промисы — узнайте о промисах Javascript, что они собой представляют и как их эффективно использовать.
- Promise chaining — показывает, как выполнять несколько асинхронных операций последовательно.
- Состав промиса:
Promise.all()
иPromise.race()
— научиться составлять новое обещание из нескольких обещаний. - Promise.any() — узнайте, как использовать метод JavaScript
Promise.any()
для возврата первого выполненного обещания - Promise.allSettled() — принимает список обещаний и возвращает новое обещание, которое разрешается в массив значений, которые были урегулированы (разрешены или отклонены) входными обещаниями.
- Promise.prototype.finally() — выполнить фрагмент кода, когда обещание выполнено, независимо от его результата.
- Обработка ошибок промисов — руководство по обработке ошибок в промисах.
- async/await — писать асинхронный код с более понятным синтаксисом.
Раздел 10. Итераторы и генераторы
- Итераторы — познакомим вас с протоколами итераций и итераторов.
- Генераторы — разработайте функции, которые могут останавливаться на полпути, а затем продолжать работу с того места, где они остановились.
- yield — узнайте, как использовать ключевое слово
yield
в генераторах. - for…of — узнайте, как использовать цикл
for…of
для перебора элементов итерируемого объекта. - Асинхронные итераторы — узнайте, как использовать асинхронные итераторы для последовательного доступа к асинхронным источникам данных.
- Асинхронные генераторы — покажут, как создать асинхронный генератор.
Раздел 11. Модули
- Модули — узнайте, как писать модульный код JavaScript.
- Динамический импорт — показать вам, как динамически импортировать модуль с помощью функционального объекта
импорт()
. - Ожидание верхнего уровня — объясните модуль ожидания верхнего уровня и варианты его использования.
Раздел 12. Символ
- Символ — познакомить вас с новым примитивным типом под названием
символ
в ES6
Раздел 13. Коллекции пары ключ-значение.
Set
, который содержит коллекцию уникальных значений.Раздел 14. Обработка ошибок
- try…catch — покажет вам, как изящно обрабатывать исключения.
- try…catch…finally – узнайте, как перехватывать исключения и выполнять блок вне зависимости от того, возникают исключения или нет.
- throw — показать вам, как генерировать исключение.
- Необязательная привязка catch — пропустить переменную исключения в блоке catch.
Раздел 15. JavaScript var, let и const
- let — объявить блочные переменные с помощью
пусть
ключевое слово. - let vs. var — поймите разницу между
let
иvar
. - const — определить константы с помощью ключевого слова
const
.
Раздел 16. Прокси и отражение
- Прокси — узнайте, как использовать прокси-объект, который обертывает другой объект (цель) и перехватывает основные операции целевого объекта.
- Reflection — покажет вам, как использовать ES6 Reflection API для управления переменными, свойствами и методами объектов во время выполнения.
Раздел 17. Среда выполнения JavaScript
- Контексты выполнения — понимание контекстов выполнения, включая глобальные контексты и контексты выполнения функций.
- Стек вызовов — понимание стека вызовов.
- Цикл событий — покажите, как JavaScript обрабатывает асинхронные операции с использованием цикла событий.
- Подъем — узнайте, как работает подъем в JavaScript.
- Области действия переменных — познакомьте вас с областями действия переменных.