Колбэки и функции высшего порядка. Фундаментальный JavaScript

Поділитися
Вставка
  • Опубліковано 9 січ 2025

КОМЕНТАРІ • 76

  • @СергейТрубников-ж6ч
    @СергейТрубников-ж6ч 9 місяців тому +7

    Если не знаете что такое коллбеки, то это лучшее видео. Спасибо вам Михаил!

    • @BuddaKun
      @BuddaKun 5 місяців тому

      Есть такая фраза, если вы чего-то ещё не знаете, значит оно вам и не нужно

  • @ЮлияЛебедева-б3и
    @ЮлияЛебедева-б3и 9 місяців тому +4

    Спасибо за понятное объяснение! Почему везде так сложно объясняют, с такими заумными для меня примерами и терминами? Ну да, я чайник. Но если бы я понимала их термины, я бы и про callback уже знала. и не рылась в инете в поисках информации. Еще раз спасибо за то, что простым языком объяснили суть callback.

  • @kirafilya
    @kirafilya Рік тому +4

    Господи, это лучшее объяснение колбэка, которое я видела! Спасибо!

  • @кал228-э4з
    @кал228-э4з 3 місяці тому

    Изучая функции,думал что они не так важны и навряд ли пригодятся.Сейчас для меня функции-чуть ли не отдельный язык программирования.Спасиьо за простое объяснение темы.

  • @yurashtefanko1603
    @yurashtefanko1603 4 роки тому +27

    Спасибо Вам. Вы единственный человек, который всё понятно объяснил. 👌👌👌

  • @vitalygaraev8093
    @vitalygaraev8093 Рік тому +4

    Неудержался что бы не написать комментарий. Очень ясный ум, ясное понимание темы и такое же прозрачное объяснение. Жаль, что больше ничего не публикуете. Спасибо!

    • @mishanep
      @mishanep  Рік тому +1

      Спасибо за похвалу.
      Видео публикую почти каждую неделю. Темы разные. На этой неделе по JS. Только плейлист другой.

  • @Umkauskas
    @Umkauskas 6 місяців тому

    спасибо, тебе. это самое доступное объяснение, что такое колбек. а до этого никак не мог понять.
    на мой взгляд, стоит добавить, что в JS функция это не просто метод, как например в Java, а объект.
    я долго не мог понять колбеки, т.к. думал, что в качестве параметра выступает результат работы функции, а не она сама.
    ещё раз спасибо.

  • @manzhosoleg
    @manzhosoleg 2 роки тому +1

    просто и точно про сложные вещи , спасибо

  • @aliana4400
    @aliana4400 2 роки тому +6

    Михаил, спасибо за этот плейлист)) очень нравится ваша манера рассказывать просто и точно про сложные для меня вещи)

  • @maratfaizer
    @maratfaizer Рік тому +1

    главное, я применял в работе hoc - но только сейчас понял, что это они и были)
    и еще реально интересное замечание, что методы работы с массивами по сути тоже hoc

  • @вадимщербинин-с3з
    @вадимщербинин-с3з 2 роки тому +2

    Михаил, спасибо большое Вам! Это тот курс, который мне был необходим. После него намного легче стало формировать логику в решении задач. Круто!

  • @profuter
    @profuter 11 місяців тому

    Наконец-то простым языком объяснили и я понял, что же такое колбэк :)

  • @AL-zg5ff
    @AL-zg5ff 3 роки тому +1

    Зашел после книги "Выразительный Javascript " 3 издание. Два дня пытался вдумчиво прочитать что же там написано в главе про функции высшего порядка. В итоге за 14 минут объяснили здесь. Спасибо огромное!

    • @lomik31_
      @lomik31_ 2 роки тому

      +++ ахахах

  • @AchtungBaby_87
    @AchtungBaby_87 2 роки тому

    вначале был реализован метод map возвращающий измененный массив) очень крутое и логичное объяснение! спасибо!

  • @marsiki_official
    @marsiki_official 3 роки тому +1

    Комент в поддержку канала 🙏

  • @ihorlevit5369
    @ihorlevit5369 3 роки тому +2

    Спасибо за обьяснение. Кстати первые две функции были примером "Чистых функций". Так что видео охватывает тему чистых функций и функций высшего порядка

  • @Aleksandr-i9
    @Aleksandr-i9 2 роки тому +1

    Гениально! У вас талант объяснять

  • @iakivpekarskyi1631
    @iakivpekarskyi1631 2 роки тому +1

    Благодарю! Очень круто объяснили!!!

  • @shyma_grasious
    @shyma_grasious 4 роки тому +1

    О боги, спасибо за такого инструктора ) очень доходчиво и понятно. Не хватило только 2-3-этажного колбека для рассмотра

    • @SomeTricks
      @SomeTricks 4 роки тому

      2-3 этажа - прошлый век. Уже ведь есть промиссы, а в es7 ввели async/await.

    • @mishanep
      @mishanep  4 роки тому +2

      Промисы и асинхронные функции тоже со временем рассмотрим на канале.

  • @ArtemSlotin
    @ArtemSlotin 2 роки тому +1

    Спасибо. Очень ясно и понятно обьясняете!

  • @nolightnohope3302
    @nolightnohope3302 Місяць тому

    спасибо за объяснение!

  • @Albert_Hall
    @Albert_Hall 2 роки тому +2

    Все прекрасно!

  • @GEO-le5ft
    @GEO-le5ft 2 роки тому +1

    отл урок. Доходчиво обьясняешь. Спасибо.

  • @faster630
    @faster630 7 місяців тому

    Даа, спасибо! Не зря подписался. Коротко и по делу.

  • @КассакСаккас
    @КассакСаккас Рік тому +1

    Коротко и яснооооооо!

  • @AGM140580
    @AGM140580 3 роки тому +1

    Большое спасибо!

  • @artyrdanilov2791
    @artyrdanilov2791 2 роки тому +1

    Отличное видео ! Многое прояснило !!!

  • @mavldr
    @mavldr 2 роки тому +1

    Спасибо за видео ❤

  • @miliba9485
    @miliba9485 3 роки тому +1

    объяснение прекрасное!

  • @sergey_zatsepin
    @sergey_zatsepin 3 роки тому +1

    Спасибо за урок

  • @ЛалаВеселова
    @ЛалаВеселова 3 роки тому +1

    все сразу стало так понятно, спасибо!!

  • @MrUnknownman1986
    @MrUnknownman1986 3 роки тому +1

    Отличное объяснение !

  • @RewCSharp
    @RewCSharp 11 місяців тому

    Спасибо за урок!

  • @Ormusic071
    @Ormusic071 3 роки тому +1

    Прекрасно объяснили, спасибо большое!

  • @MOVIE_MARA_THON
    @MOVIE_MARA_THON Рік тому

    Круто, спасибо, все очень понятно!

  • @Hakanai2022
    @Hakanai2022 Рік тому +1

    const myArr = [2, 3, 4];
    function elements(el) {
    return el * 2;
    }
    console.log(myArr.map(elements));
    вот этот код тоже будет считаться как колбэк функция? Как я понял метод тоже функция и я передаю функцию "elements" как аргумент в метод .map()

  • @gorbulevsv
    @gorbulevsv 2 роки тому

    Круто!

  • @Vladimir-ww1be
    @Vladimir-ww1be 3 роки тому +1

    Спасибо толково объясняете. Как совет, опять же хотя кому как, подумайте может немного ускорить подачу материала, смортю вас на 1.75 и параллельно код успеваю писать, может тогда просмотры увеличаться. Удачи!

    • @mishanep
      @mishanep  3 роки тому +2

      Я весь UA-cam на двушке смотрю)) при этом мне люди порой пишут, что я для них слишком быстро говорю) но я в любом случае экспериментирую. Спасибо.

    • @Albert_Hall
      @Albert_Hall 2 роки тому +2

      @@mishanep нормальная скорость, Михаил. Отличная! Кто хочет, тот ускорит. Я смотрю вас на обычной скорости и получаю удовольствие. Так как параллельно в голове прокручиваю необходимые мне сопутствующие мысли и сценарии.
      Быстрота в подаче раздражает - превращаешься в ведро, куда сливают инфу.
      Изучая что-то новое, у человека должно оставаться время на обдумывание параллельно тому, что говорит лектор.
      Если же смотришь, чтобы что-то обновить в голове, увеличиваешь скорость. И все довольны.

  • @max_ok
    @max_ok 3 роки тому +1

    👍

  • @kamol8861
    @kamol8861 2 роки тому

    оч качественно

  • @barchaan
    @barchaan Рік тому

    вау !

  • @yutbchannel
    @yutbchannel 2 роки тому

    Здравствуйте, спасибо большое за Ваше видео, все доходчиво и понятно. Мне как новичку было все ясно. но я только одного не поняла: откуда берётся аргумент num? возможно, глупый вопрос и Вы вряд ли заметите, но я просто что-то упустила из виду это...

    • @mishanep
      @mishanep  2 роки тому

      Какой таймкод? Я не помню своих видео наизусть :)

    • @yutbchannel
      @yutbchannel 2 роки тому

      @@mishanep вот к примеру 11:00 , function numSquared, её параметр num, но откуда она берет этот аргумент? я этого немного не поняла

    • @mishanep
      @mishanep  2 роки тому

      @@yutbchannel numSquared как и любая другая функция будет рассматриваться внутри copyArrayAndDoSmth по именем instructions. Поэтому когда идет вызов instructions(arr[i]), то вызывается переданный колбэек, в данном случае numSquared и ему передается значение arr[i], которое принимает параметр num

    • @yutbchannel
      @yutbchannel 2 роки тому

      @@mishanep поняла, спасибо большое!

  • @SomeTricks
    @SomeTricks 4 роки тому

    Здорово объясняешь! Но!
    1. ESLint ругается на i++ (например airbnb)
    2. Каждую итерацию цикла, вычислять .length не круто. По-хорошему ее надо перед циклом записать в переменную.
    3. Почему не использовал map вместо цикла?

    • @mishanep
      @mishanep  4 роки тому +3

      1. airbnb - жесткий, мы на работе от него отказались, используем конфиг гугла (насколько помню у него к i++ претензий не было).
      2. Length - насколько я его понимаю, это кэшированное свойство, которое автоматически меняется при изменении длины массива и не требует перерасчета при обращении к нему.
      3. Map не спользовался как раз потому, что он уже принимает колбэк, а в видео мы разбирали само понятие.

    • @olegsoul6016
      @olegsoul6016 4 роки тому

      @@mishanep 3. Цикл, окей, но почему тогда не "for of"? Более современный и лаконичный синтаксис.

    • @mishanep
      @mishanep  4 роки тому +3

      @@olegsoul6016 странные вопросы вы задаете :) для сути видео что-то принципиально от этого изменилось бы?

    • @olegsoul6016
      @olegsoul6016 4 роки тому

      @@mishanep Хм, я бы тогда сказал - странный ответ ваш на мой вопрос)) Раз все равно что использовать, для чего вы тогда показываете современные методы, что отличает их от более старых (кстати в том же самом примере в цикле вы почему-то использовали для возведения в степень метод из ES6, а не Math.pow()...)? И, мне казалось, отвечать вопросом на вопрос, не очень культурно...сори, если чем-то задел вас, я просто хотел разобраться в вашей логике подачи материала.

    • @mishanep
      @mishanep  4 роки тому

      @@olegsoul6016 не вижу смысла вступать в прения. На мой взгляд для логики изложения конкретного видео не было никакой разницы. Возможно и был какой-то умысел, когда готовился материал для видео, но спустя два месяца после публикации об этом уже сложно что-то сказать.

  • @НиколайТурищев-л6р

    Спасибо за видео! Но одно для меня остается непонятным, почему Вы называете сущность, являющуюся по сути просто делегатом, callback-функцией? Ведь "издревна" callback-функция - это функция назначение которой быть выполненной по завершении работы другой функции в которую она и передана для этого. И название у нее соответствующее. Либо это так принято в JS? Странно...

    • @mishanep
      @mishanep  4 роки тому

      Думаю вы правы, отчасти здесь действительно смешиваются два понятия. Но в среде JavaScript, насколько я встречаю, и то и другое называется колбэком.

  • @Emil-ey7pn
    @Emil-ey7pn 2 роки тому

    А как элементы массива автоматически идут в nam?

    • @im_dmitriy
      @im_dmitriy 2 роки тому

      Элементы массива не "идут автоматически в num". Смотрите на функции numSquared и divideBy2 как на формулы, которые мы вкладываем в функцию copyArrayAndDoSmth в качестве аргументов при её вызове. Эти аргументы (формулы) заменяют параметр instructions в теле функции copyArrayAndDoSmth. С помощью этого параметра (instructions) мы производим соответствующие вычисления над числами, которые стоят первым аргументом функции copyArrayAndDoSmth.

    • @ОлегД-э2ъ
      @ОлегД-э2ъ 2 роки тому

      @@im_dmitriy добрый день. А можно ли таким способом вывести четные/нечетные числа. Я попытался, он лишь проверяет их, выводит true или false

    • @im_dmitriy
      @im_dmitriy 2 роки тому

      @@ОлегД-э2ъ добрый... Попробуйте таким образом:
      function getOddNum(num) {
      if (num % 2 !== 0) {
      return num;
      } else {
      return false;
      }
      }

    • @im_dmitriy
      @im_dmitriy 2 роки тому

      @@ОлегД-э2ъ Предлагаю сперва показать свой вариант : )

    • @im_dmitriy
      @im_dmitriy 2 роки тому

      @@ОлегД-э2ъ Интересное решение. Вместо простенького else if такая хитрая штука : )

  • @mityadima
    @mityadima 3 роки тому

    А когда замыкания рассмотрите?

    • @mishanep
      @mishanep  2 роки тому

      Давно уже есть на канале ua-cam.com/video/BOjr2L3VXsc/v-deo.html

  • @treXXXter
    @treXXXter Рік тому

    Спасибо !

  • @ginhop1057
    @ginhop1057 2 роки тому +2

    Хорошее объяснение👍