Что такое ЗАМЫКАНИЯ в JavaScript? Как они работают? Разберём на примерах

  Рет қаралды 3,496

Эльбрус Буткемп: школа программирования

Эльбрус Буткемп: школа программирования

Жыл бұрын

Хотите поближе познакомиться с форматом буткемпа? Тогда записывайтесь на день открытых дверей по ссылке 👉🏻 go.elbrusboot.camp/opendays-js
Участвуйте в бесплатном мастер-классе по JavaScript 👉🏻 go.elbrusboot.camp/mk-js-adva...
Кто мы такие❓
Elbrus Coding Bootcamp - это первая и самая крупная в России школа программирования в формате интенсивного обучения. Студенты 12 недель оффлайн или 15 недель онлайн практикуются на реальных проектах и кодят с утра до вечера. Обучение проходит по направлениям JavaScript и Data Science.
В буткемпе студенты решают задачи от реальных работодателей, что особенно важно в постоянно развивающейся сфере IT. 3 месяца оффлайн / 4 месяца онлайн обучения с 9:00 до 19:00 5 дней в неделю, ежедневная работа с кодом, плюс два проекта, командный и персональный, которые студенты защищают на второй и третьей, заключительной, фазе обучения - и вот на выходе уже есть полноценное портфолио, которое можно показать при устройстве на работу.
По окончании обучения всех ждет карьерная неделя, где карьерный коуч помогает подготовиться к собеседованию, подтянуть софт-скиллы и собрать резюме, с которыми 93% студентов находят работу в течение трех месяцев после окончания буткемпа. Также после завершения Elbrus Bootcamp есть возможность получить диплом ДПО.
Приходите на день открытых дверей в онлайне и познакомьтесь с форматом буткемп. Это лучший способ научиться программировать, сменить работу и увеличить свой доход.
VK - elbrusbootcamp
FB - / elbrusbootcamp
Insta - / elbrus.bootcamp
TikTok - www.tiktok.com/@elbrusbootcam...
Сайт школы - elbrusboot.camp
Напишите или позвоните нам, чтобы узнать, как поступить в ближайшую группу:
☎️ +7 (499) 938-68-24
💬 Чат в WhatsApp api.whatsapp.com/send?phone=7...
💬 Чат в Телеграм t.me/elbrusbootcamp1
✉️ info@elbrusboot.camp
Использовалось в видео (музыка/видео):
Gemini - half.cool

Пікірлер: 20
@MyNameIsEd2d2
@MyNameIsEd2d2 Жыл бұрын
Юр спасибо огромное! Два дня смотрел/читал всякое и не мог допереть что такое замыкание и где оно применяется, теперь картинка сложилась
@EkaterinaYulina
@EkaterinaYulina Жыл бұрын
Автор очень доходчиво рассказывает! Рекомендую
@MsSapfy
@MsSapfy Жыл бұрын
Спасибо, поняла с первого раза 👌
@EvilGazz
@EvilGazz Жыл бұрын
Отличный пример👌
@user-vn7ru7xk2k
@user-vn7ru7xk2k Жыл бұрын
Объективно адекватно
@Zikyzi
@Zikyzi Жыл бұрын
Спасибо!
@user-ge9lz2zx6d
@user-ge9lz2zx6d Жыл бұрын
ТОП!!
@user-gm2dm9ps2j
@user-gm2dm9ps2j Жыл бұрын
Огонь!
@darinka6024
@darinka6024 Жыл бұрын
Юра 🔥🔥🔥
@user-il3zt5kc3q
@user-il3zt5kc3q Жыл бұрын
❤❤❤
@novichok3417
@novichok3417 7 ай бұрын
Юрий спасибо за попытку объяснить тему замыкания в js . На мой взгляд не очень удачная. 2-е в вашем видео примерно с 20-21минуты вы рассказываете тему(в другом видео, другой блогер назвал её function factory) и там он сказал,что передовать два аргумента в фунцию почему-то не очень хорошо. Для краткости закончилось все прередачей двух аргументов в отдельных круглых скобках (как у вас) . Не могли бы вы рассказать тему function factory и ещё тему геттеров и сеттеров и нормально объяснить для чего они нужны.
@ElbrusBootcamp
@ElbrusBootcamp 7 ай бұрын
Вы ссылаетесь к тому, что понятие function factory чем-то похоже на каррирование. В каррировании мы стараемся уйти от нескольких аргументов в пользу одного, а в function factory мы больше концентрируемся на расширении функционала или конфигураций готовой функции. В видео есть пример с функцией someFunction5()() , его можно отнести к обоим этим понятиям. Тем не менее, обе эти концепции работают на замыкании, и придуманы для демонстрации и объяснений начинающим в JavaScript.
@flightcommunity.kingsofthe6606
@flightcommunity.kingsofthe6606 Жыл бұрын
Отличный урок! Давно слышал про замыкания, но никак не мог понять, после видео стало ясно) Подскажите где можно попрактиковаться на замыкания?
@user-dr7im3tk3e
@user-dr7im3tk3e 5 ай бұрын
То есть основная фишка замыкания в том, что оно сохраняет значение предыдущих вызовов функции? Иными словами переменные лексического окружения (scope) сохраняются и соответственно эти сохранённые значения в переменных используются при следующих вызовах функции ?
@ElbrusBootcamp
@ElbrusBootcamp 5 ай бұрын
Да, всё верно. Основное применение замыкания это сохранение доступа к переменным из внешней функции, даже после того, как она завершила свою работу. Это позволяет функции использовать и изменять значения этих переменных, что делает их очень гибкими. В рабочих примерах замыкания могут быть полезными, когда нужно сохранить состояние или создать приватные переменные в JavaScript.
@Alexander_Shulga_
@Alexander_Shulga_ 7 ай бұрын
Юра, Вы 35 минут силились объяснить, что такое замыкание, но похоже Вы и сами не до конца разобрались в этой теме. Замыкание это всего лишь вот это: { var1; get_var1{ return var1; } set_var1{ var1 = 5; } } Внешние фигурные скобки, внутри которых объявлены две подпрограммы, являются обозначением контекста, внутри которого есть данные и эти две подпрограммы. В роли контекста может быть внешняя подпрограмма или какой-то блок операторов. Замыкание - это когда доступ к переменной var1 извне блока кода, в котором она объявлена, отсутствует, т.е. нельзя воспользоваться так: имя-блока-кода.var1 = 4; Но подпрограммы, которые внутри этого блока были объявлены, имеют к ней доступ в силу того, что при замыкании подпрограммы имеют доступ к среде, в которой они были объявлены. Т.е. можно написать: set_var1(); w = gen_var1(); То, что эти две функции имеют доступ к переменной var1 - это и есть замыкание, т.е. доступ функции к переменной той среды, в котором эта функция была определена. При этом, если потом написать так set_var1(); var1 = 10; w = gen_var1(); то w все равно будет содержать 5, потому что функции работают с var1 из среды, в которой они были определены, а не с той переменной var1, которую мы ввели потом.
@ElbrusBootcamp
@ElbrusBootcamp 7 ай бұрын
вы действительно хорошо пояснили понятие замыкания, с учётом примера с псевдокодом. Ваш пример строится на геттере и сеттере, что вполне имеет место быть и может применяться. Тем не менее замыкание не заканчивается только на get-set, есть много разных способов демонстраций. Основная задача видео показать пример постепенного уложения функции с учётом замыкания для тех кто впервые сталкивается с этим инструментом. Спасибо за ваш комментарий!
@Alexander_Shulga_
@Alexander_Shulga_ 7 ай бұрын
👍@@ElbrusBootcamp
@user-rk1rp1ni5w
@user-rk1rp1ni5w Жыл бұрын
Это же видео для уже работающих програмистов знающий это язык. Я пробовал изучать пайтон, со второго просмотра чуть-чуть понял. Человек с 0 знаниями не понимает даже что это за программа. Это урок не для новичков!
@ElbrusBootcamp
@ElbrusBootcamp Жыл бұрын
Здравствуйте! Тема замыканий важна для понимания, когда базовые темы уже разобраны. Также эта тема часто встречается на собеседованиях, и нашей задачей было помочь с подробным разбором. Расскажите, какие темы вам было бы интересно увидеть в будущем на нашем канале? Вы уже начали знакомство с синтаксисом JS?
Замыкания, просто и с примерами. Функции JavaScript
39:25
WebDev с нуля. Канал Алекса Лущенко
Рет қаралды 44 М.
Mini Jelly Cake 🎂
00:50
Mr. Clabik
Рет қаралды 18 МЛН
Chips evolution !! 😔😔
00:23
Tibo InShape
Рет қаралды 9 МЛН
Что такое промисы в JavaScript. Фундаментальный JavaScript
24:51
Михаил Непомнящий
Рет қаралды 40 М.
JavaScript v.2.0. Замыкания
22:58
WebDev с нуля. Канал Алекса Лущенко
Рет қаралды 43 М.
Полный гайд по JavaScript собеседованию. Все в 1 видео!
1:41:32
Замыкания в JavaScript с примерами. Фундаментальный JavaScript
22:39
Node JS - Быстрый Курс за 1 час
1:01:52
Владилен Минин
Рет қаралды 534 М.
Эти фреймворки и библиотеки вам могут понадобиться! Лучшие инструменты для JavaScript
10:13
Эльбрус Буткемп: школа программирования
Рет қаралды 150