Просто o async, await. Без циклов и таймеров. JavaScript

  Рет қаралды 102,093

WebDev с нуля. Канал Алекса Лущенко

WebDev с нуля. Канал Алекса Лущенко

Күн бұрын

Пікірлер: 224
@ildarjakparov4887
@ildarjakparov4887 3 жыл бұрын
4:16 - порядок такой не потому что запрос к серверу дольше, а потому что fetch возвращает промис, а промисы исполняются после основного стека вызова, так как сидят в microtask queue.
@ivomeadows
@ivomeadows 3 жыл бұрын
топовый коммент. об этом надо было рассказать
@faizulla5838
@faizulla5838 3 жыл бұрын
те если делать async/await без fetch то порядок будет любой? Спасибо
@ivomeadows
@ivomeadows 3 жыл бұрын
@@faizulla5838 функция async всегда возвращает промис
@АндрейИванов-ц3к2л
@АндрейИванов-ц3к2л 2 жыл бұрын
Интересно, а где в данном случае основной стек вызова?
@oleksandrs7407
@oleksandrs7407 2 жыл бұрын
Крайне важный коммент, в топ.
@TheChiefEngineer-RB
@TheChiefEngineer-RB 4 жыл бұрын
Долгих лет здоровой жизни вам!) Всегда радуйте нас вашим понятным контентом!
@pavel7930
@pavel7930 4 жыл бұрын
Это гениально! Большое спасибо ! Самое понятное объяснение которое видел когда либо!
@grach1993
@grach1993 4 жыл бұрын
Было понятно, но всё-равно в уме витали какие-то сомнения. Благодаря такой подаче они полностью развеялись. Спасибо
@omnomnom1323
@omnomnom1323 3 жыл бұрын
ну наконец-то!!!! хоть где-то реальный кейс с запросом на сервак без этих сеттаймаутов! Спасибо)
@olexanderChorny
@olexanderChorny 4 жыл бұрын
Через какие мучения пришлось пройти, что бы это понять! У вас максимально доступно, большое, человеческое спасибо)
@ДанилДмитриев-я5м
@ДанилДмитриев-я5м 2 жыл бұрын
да хватит это легко
@AnonAristotel
@AnonAristotel 4 жыл бұрын
Хммм... - А давайте чтобы у нас код не был последовательным придумаем асинхронные вызовы. - Ой, а у нас же нарушается последовательность выполнения кода и он становится асинхронным. - А давайте мы придумаем ожидание выполнения асинхронного кода, чтобы выполнение его было последовательным и ожидаемым.
@dimape.4180
@dimape.4180 3 жыл бұрын
хмм.. а давай при каждом запросе на сервер, если там задержка, будем ковырять в носу и ждать ответа и не будем придумывать асинхронные вызовы
@AnonAristotel
@AnonAristotel 3 жыл бұрын
@@dimape.4180 Нет, давайте делать это, покуда будем ожидать (await) выполнение асинхронных вызовов.
@dimape.4180
@dimape.4180 3 жыл бұрын
Нет давайте поделаем что-нибудь другое, это же асинхронный вопрос.
@AnonAristotel
@AnonAristotel 3 жыл бұрын
@@dimape.4180 В том то и дело, что с await это выглядит как обычный синхронный код. Это не go рутины и не фоновые задания 1С. Кстати почти те же йайтса в 1С, только там сначала реализовали через широковещание - ОбработкаОповещения, а потом через Acync (Асинх) Await (Ждать). И в такой конструкции результат выглядит как обычный синхронный код. Только выполняется раз в 10 медленнее. А знаете почему? Потому что 1С тоже имеет (какое слово то гадкое) web клиент. И проблема в том, что браузер ругается на синхронные вызовы и не даёт их выполнять. То есть средство просмотра (браузер) де-факто устанавливает правила для языков программирования и фреймворков.
@dimape.4180
@dimape.4180 3 жыл бұрын
Если их придумали значит в них была потребность для опред. ситуаций.
@ТатьянаХоружая-ц1н
@ТатьянаХоружая-ц1н 2 жыл бұрын
Кучу видео посмотрела и пришла к итого, что ваши видео самые доступные, а также результативные! Огромное вам спасибо!
@OlyaPoy
@OlyaPoy 3 жыл бұрын
Огромное спасибо. Благодаря вашему обьяснениям смогла ответить на вопросы на собеседовани и меня взяли на стажировку!
@braingriffin946
@braingriffin946 Жыл бұрын
Как дела спустя год?
@anti_middle_ages
@anti_middle_ages Жыл бұрын
@@braingriffin946 Видимо, плохо
@ФорменШульц
@ФорменШульц 9 ай бұрын
да как у вас дела?
@avs1978
@avs1978 9 ай бұрын
Посмотрела видос, взяли на работу, за это время никто не оставлял комментарии под видео и она написала первый комментарий. Автор, самому не смешно?
@ФорменШульц
@ФорменШульц 9 ай бұрын
​@@avs1978в чем прикол?
@evgeniy3224
@evgeniy3224 4 жыл бұрын
У вас всегда уроки понятно о сложном. Большое спасибо, было очень полезно. Размял свои мозги!))
@НиколайСтепанов-ю3м
@НиколайСтепанов-ю3м Жыл бұрын
Самый лучший канал по JavaScript, постараюсь и платный ваш курс пройти!
@user-lilya
@user-lilya Жыл бұрын
Спасибо, очень полезное видео! наконец-то поняла тему.
@katemos4584
@katemos4584 2 жыл бұрын
Александр Лущенко лучший блогер, коучер и программист. Спасибо огромное!!!!!!!!!!!!!!
@екатеринапанасюк-и6ч
@екатеринапанасюк-и6ч 2 жыл бұрын
Вы отличный учитель!Спасибо Вам большое!
@АлександрСмирнов-ы5т7ч
@АлександрСмирнов-ы5т7ч 4 жыл бұрын
Спасибо , очень полезно!! понятно все очень!! теперь не много перепишу свой телеграмм-бот.
@kenanhaciyev3759
@kenanhaciyev3759 2 жыл бұрын
это лучшее объяснение async await что может быть вообще!!!!!!
@andreybalatsan9336
@andreybalatsan9336 2 жыл бұрын
Спасибо огромное, посмотрел уже 3 видео и на вашем все встало на свои места
@Kras99free
@Kras99free 2 жыл бұрын
Лучшее объяснение асинхронности из всего что есть на русскоязычных ресурсах!
@DmytroZaika-hn7wx
@DmytroZaika-hn7wx 8 ай бұрын
Спасибо большое, это четвертое видео которое я смотрю на эту тему и только сейчас стало понятно
@venzeldv
@venzeldv Жыл бұрын
Лучшее описание, что мне встретилось.
@sergeyplotnikov5031
@sergeyplotnikov5031 4 жыл бұрын
Спасибо за такое простое и понятное объяснение
@RomanKaras77
@RomanKaras77 4 жыл бұрын
Александр, всегда с удовольствием смотрю ваши видео, хоть вроде и не новичок ). Не примите за занудство, но попробуйте писать в vscod-e не console.log(), а просто log и клавиша Tab. И перемещать строки или выделенные фрагменты кода, когда вы меняли, например местами функции f1() и f2(), можно Ctrl + Shift + стрелки вверх/вниз )), а не копипастом. С уважением. Спасибо за ваш труд, жму руку. )
@untiweuntiwe7415
@untiweuntiwe7415 4 жыл бұрын
Про log + tab тоже не знал. Только log + enter. Спасибо)
@RomanKaras77
@RomanKaras77 4 жыл бұрын
@@untiweuntiwe7415 я кстати, далеко не сразу в работе с вс-кодом узнал про передвижение строк и очень был обрадован этой фичей )
@alexfargo6336
@alexfargo6336 2 жыл бұрын
Большое спасибо, Сань, твоё видео помогло мне выйти из ступора и решить мою проблему)
@ИгорьКосач-ф8л
@ИгорьКосач-ф8л Жыл бұрын
Это очень грамотно разжевано. После 5 -6 видосов на эту тему, этот самый лаконичный и понятный.
@oleksandrkotovskyi4203
@oleksandrkotovskyi4203 29 күн бұрын
как всегда шикарно рассказано на пальцах
@TONY_BERG_ELECTRO
@TONY_BERG_ELECTRO 5 ай бұрын
Чертов Гений❤❤❤🎉
@adinaijamangulova2596
@adinaijamangulova2596 3 жыл бұрын
один из лучших каналов по веб-разработке! ВСе понятно и ясно!
@alla6361
@alla6361 Жыл бұрын
Спасибо! Стало понятнее!
@ПолинаКызылова
@ПолинаКызылова 9 ай бұрын
лучшее видео эвер, спасибо большое!!!
@МилаяЛюбимая-ч3к
@МилаяЛюбимая-ч3к 2 жыл бұрын
Спасибо за объяснение, единственный кто легко донес смысл async await)))
@niteilcaesgo2907
@niteilcaesgo2907 Жыл бұрын
Большое спасибо за видео! очень понятное объяснение!
@АлександрБуров-п1м
@АлександрБуров-п1м 2 жыл бұрын
Спасибо, только после этого видео наконец понял что это такое!)
@тоталіспайс
@тоталіспайс 4 жыл бұрын
Шикарно, как раз на главе по асинхронности в Eloquent JavaScript и понимаю, что это видео хорошенько мне поможет) Спасибо
@ОлегСавл
@ОлегСавл 2 жыл бұрын
Спасибо огромное, у Вас очень хороший подход и объяснение технологии. Успехов!
@yuriyovdeyev685
@yuriyovdeyev685 4 жыл бұрын
Толково! Спасибо за пример, очень наглядно и понятно.
@_l.e.n.y_4956
@_l.e.n.y_4956 2 жыл бұрын
Ви найкращий вчитель IT
@valerakuznetsov
@valerakuznetsov 2 жыл бұрын
спасибо громадное Вы один кто так доходчиво рассказал
@Play_True
@Play_True Жыл бұрын
Действительно полезное видео, объясняющее работу асинхронных функций
@sedovolosyi
@sedovolosyi 2 жыл бұрын
Суть понятна, спасибо. Функция go имеет лишний async, ну это мелочи
@andrzeyshliaha5302
@andrzeyshliaha5302 4 жыл бұрын
Здорово, все по делу без воды, спасибо
@andrzeyshliaha5302
@andrzeyshliaha5302 4 жыл бұрын
Правильно я понял, если например потом с данными нужно делать определенную логику а не просто текст, например в функции f3 то мы там просто ее и пишем ?
@Olegio_Y
@Olegio_Y 2 жыл бұрын
Спасибо что делаете упор на простоту обьяснения
@valentyn996
@valentyn996 3 жыл бұрын
Отличное объяснение, спасибо за старания!
@Lunar66
@Lunar66 Жыл бұрын
не ожидал вас тут увидеть:)
@valentyn996
@valentyn996 Жыл бұрын
@@Lunar66 😎😎
@ИльяЗахаров-е3э
@ИльяЗахаров-е3э Жыл бұрын
Спасибо) Очень подробно объяснили)
@annajegorova6120
@annajegorova6120 2 жыл бұрын
Спасибо за видео, простой и понятный пример!
@КириллДубасов-ф7б
@КириллДубасов-ф7б 3 жыл бұрын
Лучшее объяснение асинхронности, огромное вам спасибо!
@Olena_salii
@Olena_salii 2 жыл бұрын
Очень хорошее обьяснение для новичков! доступно! благодарю!
@aleks6607
@aleks6607 2 жыл бұрын
Спасибо)) очень помог ваш видос))
@МишаАстахов-ю2д
@МишаАстахов-ю2д 3 жыл бұрын
Наконец то, классно обьяснил ! , уникально, супер, понятно !
@knuckless__
@knuckless__ 2 жыл бұрын
дуже доступно та легко дякую)
@mediavova407
@mediavova407 3 жыл бұрын
Огромное спасибо!!! Всё доходчиво на 150%, закрыли мои многие вопросы
@СултанТемирбай-и8я
@СултанТемирбай-и8я 3 жыл бұрын
и человек и видео прекрасны спасибо большое
@tazorprod.934
@tazorprod.934 Жыл бұрын
Очень доступно объяснили такую сложную тему, спасибо
@HeorhiiHryhorian
@HeorhiiHryhorian Жыл бұрын
Очень хорошее видео! Спасибо за труд!
@Das.Kleine.Krokodil
@Das.Kleine.Krokodil 3 жыл бұрын
0:23 так вы рассказываете про асихроннные функции или про то как асинхронные сделать синхронными?
@yaroslavzef7267
@yaroslavzef7267 3 жыл бұрын
Круто. Не знал за такую тему! Спасибо
@СергейКузнецов-т4р
@СергейКузнецов-т4р 3 жыл бұрын
Очень благодарен. Лущенко the best ))))
@МастерЙода-я4ю
@МастерЙода-я4ю 3 жыл бұрын
Спасибо, помог разобрасять с промисами и эсин эвей.
@ИванНазаров-р8л
@ИванНазаров-р8л 4 жыл бұрын
Александр не лучше ли для эмуляции сервера использовать jsonplaceholder ? мне кажется будет нагляднее и интереснее
@asgard1428
@asgard1428 2 жыл бұрын
Все равно до конца не понял. Но это лучшее объяснение что я видел. Спасибо!
@tihunvolkov9288
@tihunvolkov9288 Жыл бұрын
Наконец-то, без таймеров, на нормальном реальном примере, ободряю.
@aleksey220280
@aleksey220280 4 жыл бұрын
Очень доступная подача. Спасибо!
@_Iokanaan_Marusidze_
@_Iokanaan_Marusidze_ 4 жыл бұрын
Спасибо, Александр ! Вы один из тех немногих кто расказывает о сложном простыми словами и способствует развитию хода мысле в ученике. По моему разумению именно таким и должен быть настоящий УЧИТЕЛЬ. ------------------------- Посдскажите пожалуйста, какие инструменты нужно задействовать в JS чтобы добиться четкого выполнениея таймингов ? Мне нужно чтобы функции вызывались с четкой переодичностью в 1сек и 500мс и весьма желайтельно чтобы этот таймер имел общее основание с Date(), поскольку именно оттуда я беру текущее время.
@_Iokanaan_Marusidze_
@_Iokanaan_Marusidze_ 4 жыл бұрын
@@enjoymtx , не получается его отследить потому что тайминги Date() и Setinterval просто не совпадают. Может в системе Можна как то выйти на единый источник тактирования ? Здесь нужно понимать тонкости работы движка js.
@_Iokanaan_Marusidze_
@_Iokanaan_Marusidze_ 4 жыл бұрын
@@enjoymtx , к примеру. Через setinterval я вызываю ф-цию каждую секунду, в начале этой ф-ции я проверяю равны ли мс обьекта Data() нулю. И вот здесь и трабла, они никогда не равны нулю. Как тогда я спрашиваю выдержать точные интервалы ?
@ПращурАмбатьелло
@ПращурАмбатьелло 3 жыл бұрын
это делается через рекурсивный setTimeout
@gom-jabbar
@gom-jabbar 11 ай бұрын
Благодарю
@dilmurodshernodirov5984
@dilmurodshernodirov5984 4 жыл бұрын
Спасибо за видос ждём по больше ещё
@karenmelikyan377
@karenmelikyan377 2 жыл бұрын
Гениальный язык. И без async функция асинхронна и с async асинхронна. Главное, надо было все сделать работающим асинхронно, а потом выдумывать кастыли как все это синхронизировать. Просто гениально.
@maratkamaletdinov9017
@maratkamaletdinov9017 2 жыл бұрын
Единственное, что понял, что асинхронность нужна, чтобы функции работали синхронно. Потому что без асинхронности они работают...асинхронно.
@SputnikovoeTV
@SputnikovoeTV 3 жыл бұрын
Не совсем пойму разницу с Промисами( фетч вернет промис, и зеном обработаем по цепочке и по сути это тоже самое?
@maksymkyryliuk492
@maksymkyryliuk492 2 жыл бұрын
Good work. Awesome explanation!👍
@sekirogenshiro2210
@sekirogenshiro2210 3 жыл бұрын
Спасибо! Наконец то все понятно стало!
@RinatWOT
@RinatWOT 3 жыл бұрын
Спасибо большое! Очень круто объяснил
@bunnybugs6623
@bunnybugs6623 3 жыл бұрын
Все супер, но Все же нужно пересмотреть, очень интерестно работа над ошибками
@mike-aaa
@mike-aaa 2 жыл бұрын
Ради этого урока я написал свой сервер! 😎
@ops_rv
@ops_rv 3 жыл бұрын
Дякую, як завжди просто і доступно 👍
@АлександрИванов-ц6ф4в
@АлександрИванов-ц6ф4в 4 жыл бұрын
мегачеткий видосик - впрочем как обычно
@АлексейЛоскутников-ю4р
@АлексейЛоскутников-ю4р 4 жыл бұрын
Хороший пример, спасибо. Еще можно разобрать на вашем примере обработку ошибок при асинхронных запросах. На простых примерах, как правило это упускают, а на продакшен без этого никак.
@sega21rus98
@sega21rus98 4 жыл бұрын
просто в async функции используешь try-catch и все
@dreadwood
@dreadwood 3 жыл бұрын
Доступное и понятное объяснение, спасибо. Интересно посмотреть код сервера. Может есть пример где-нибудь на github?
@GTar1998
@GTar1998 3 жыл бұрын
Все просто и понятно. Спасибо
@georgepetrosyan4589
@georgepetrosyan4589 4 жыл бұрын
Александр,как всегда респект. Наконец-то, кто-то понятно и на пальцах объяснил асинк-эвеит. А с помощью промисов, такого же результата можно добиться, посмотрев вашу лекцию про промисы?
@UlmanALA
@UlmanALA 3 жыл бұрын
Офигенно объяснили!!! Спасибо!
@araslanrus
@araslanrus 3 жыл бұрын
Наконец то без циклов и таймаутов
@GGSoft2009
@GGSoft2009 2 жыл бұрын
Ну это и лекция. Спасибо больщое
@Synchro13
@Synchro13 3 жыл бұрын
Огромное спасибо! просто и понятно
@АрсенМахмудов-н2д
@АрсенМахмудов-н2д 3 жыл бұрын
С меня подписка! Вот так нужно объяснять чайникам))
@sergeyilyin756
@sergeyilyin756 3 жыл бұрын
Это определено одно из лучших объяснений, а самое главное без таймаутов и интервалов со стрелочной функцией, который только запутают новичка. Спасибо, подписываюсь!
@digitalturkistan1857
@digitalturkistan1857 2 жыл бұрын
Такие подачи для того что бы показать какой он крутой программист типа владилена
@gordonfram
@gordonfram 2 жыл бұрын
@@digitalturkistan1857 нет. Данный автор никак не хвастается и не "намекает" на то, какой он классный программист
@alexforos5425
@alexforos5425 3 жыл бұрын
Спасибо большое! 👍
@mikhailurban1222
@mikhailurban1222 3 жыл бұрын
как всегда супер!
@dinarsharipov5022
@dinarsharipov5022 3 жыл бұрын
Спасибо.наконец понял я как правильно прописывать асинк эвэйт, единственное, наверное можно было бы внутри каждой функции не прописывать async await? или обязательно дважды прописывать??
@kapwas
@kapwas 2 жыл бұрын
Что будет, если асинк авэйт оставить только у обертки, а сами ф1-ф3 обычными обозвать без авэйтов внутри?
@pypypy4228
@pypypy4228 2 жыл бұрын
Наконец-то стало понятно, что async await фактически делают из асинхронного кода подобие синхронного.
@МишаАстахов-ю2д
@МишаАстахов-ю2д 3 жыл бұрын
Бомба 💣!
@Vetala007
@Vetala007 4 жыл бұрын
спасибо, стало гораздо понятнее)))
@DAROM-TK
@DAROM-TK 3 жыл бұрын
Спасибо за видео, вроде все понятно и очевидно, но полнз читать на официальный сайт про асинхронность, и снова запутался. В официальном примере код выполняется последовательно, там запускают рисование миллиона шариков, и пока они не нарисуются, следующий за ним алертт не выполняется, баузер зависает. В Вашем же примере как раз этого нет, выводы в консоль выполняются именно , что быстрее то и выводится. Как так получается, в ситуации с шариками все идёт последовательно, а при выводе в консоль нет? Вот пример оттуда function expensiveOperation() { for(let i = 0; i < 1000000; i++) { ctx.fillStyle = 'rgba(0,0,255, 0.2)'; ctx.beginPath(); ctx.arc(random(0, canvas.width), random(0, canvas.height), 10, degToRad(0), degToRad(360), false); ctx.fill() } } fillBtn.addEventListener('click', expensiveOperation); alertBtn.addEventListener('click', () => alert('You clicked me!') );
@timzeynalov3537
@timzeynalov3537 3 жыл бұрын
вы все такие молодцы ) а когда появится такая услуга чтобы вот ну я завис к какой то теме например асинхронность и мне нужно чтобы учитель мне показал че и как ) а оплата по зеленым оценивается ну как бы час 50 долларов или 60 ну если скидка есть то буду часто обращаться )
@itgid
@itgid 3 жыл бұрын
я вас не понял....
@timzeynalov3537
@timzeynalov3537 3 жыл бұрын
@@itgid я хочу заниматься индивидуально по разным вопросам я иду по пути Fullstack если мы могли бы оказывать услуги то мы могли бы вместе работать я был бы вашим учеником VIP
@АлександрЛавренюк-о9ь
@АлександрЛавренюк-о9ь 2 жыл бұрын
Подскажите, как с помощью async/await дождаться появления DOM-элемента и выполнить с ним действие? За урок спасибо!
@Alias_s
@Alias_s 2 жыл бұрын
document.addEventListener("DOMContentLoaded", function(event) { //do work });
@xelth
@xelth Жыл бұрын
при авейт ждет только эта функция или оно тормозит функции работающие в паралели?
@ivanlomov1994
@ivanlomov1994 2 жыл бұрын
Фетч возвращает промис, который выполнится после синхронных операций
@ИванВерушкин-в7ю
@ИванВерушкин-в7ю 2 жыл бұрын
А как правильно перебрать циклом этот res? То есть, допустим, запрос возвращает некий массив данных, а мне из этого массива нужно что-то конкретное выводить в консоль или на экран.
@ForseNight
@ForseNight Жыл бұрын
Лучший айтиевангелист
@itgid
@itgid Жыл бұрын
Не. Максимум айтиатеист. Я за то что айти не является чем-то недостижимым.
@airjuicex
@airjuicex 3 жыл бұрын
Заебись , по человечески
@faizulla5838
@faizulla5838 3 жыл бұрын
Извините , Алексей а если порядок не важен, главное чтобы не ждало и работало - async/await применяем или старый вариант? если да то как?
@donatelodonatelo383
@donatelodonatelo383 2 жыл бұрын
Фактически я могу и не взять в async каждую функцию по одельности? Ведь возможно каждую синк функцию сделать асинк с добавлением awair в начале?
Просто о promise в JavaScript
12:52
WebDev с нуля. Канал Алекса Лущенко
Рет қаралды 136 М.
03. Асинхронность в JS - Григорий Бизюкин
1:08:39
Yandex for Frontend
Рет қаралды 56 М.
BAYGUYSTAN | 1 СЕРИЯ | bayGUYS
36:55
bayGUYS
Рет қаралды 1,9 МЛН
Beat Ronaldo, Win $1,000,000
22:45
MrBeast
Рет қаралды 158 МЛН
Что такое промисы в JavaScript. Фундаментальный JavaScript
24:51
Михаил Непомнящий
Рет қаралды 46 М.
JavaScript событийный цикл Event Loop, асинхронный код, промисы (Promise), async / await
24:03
Простыми словами про Async Await с примерами [JavaScript]
22:31
Не бойтесь регулярных выражений. Regex за 20 минут!
34:20
WebDev с нуля. Канал Алекса Лущенко
Рет қаралды 237 М.
Asyncio и асинхронное программирование | Python 3, Питон 3
41:01
Андрей Иванов | Python
Рет қаралды 38 М.