Чудовищно функциональный JavaScript

Поделиться
HTML-код
  • Опубликовано: 23 дек 2024

Комментарии •

  • @Howtogoit
    @Howtogoit  3 года назад +11

    Тренажеры HTML Academy (HTML, CSS, JS, React) + Академия + Книга рецептов фронтендера + комьюнити
    за 99 рублей:
    boosty.to/how-to-learn-it
    Какие тренажеры бывают:
    htmlacademy.ru/courses#fe-start
    Подписывайтесь:
    t.me/howToLearnIT
    ______________________________
    Файлик с некоторыми примерами
    codesandbox.io/s/focused-kate-hq4ef?file=/src/index.js
    Компоненты высшего порядка в React js
    ru.reactjs.org/docs/higher-order-components.html
    _____________________
    Для видео я использовал материалы из этих статей:
    1) maddevs.io/insights/blog/functional-programming-principles-in-javascript/#first-class-functions
    2) www.telerik.com/blogs/functional-programming-javascript
    3) opensource.com/article/17/6/functional-javascript
    4) blog.bitsrc.io/functional-programming-in-javascript-how-and-why-94e7a97343b
    5) learn.javascript.ru/currying-partials
    Спасибо авторам, хоть многие из них никогда не посмотрят эти видосы из-за языкового барьера)
    #JavaScript #reactjs #functionalprogramming #frontend

  • @DmytroB-m9g
    @DmytroB-m9g 3 года назад +72

    Какие же чистые у тебя ролики.
    А композиция то какая!

  • @Megabarm2000
    @Megabarm2000 2 года назад +1

    После такого видео не грех и подписаться, да что уж там и колокольчик зажать тоже!!!!😅

  • @fuad2069
    @fuad2069 3 года назад +71

    С таким уровнем объяснения, и раскрытия важностей тем, вы должны быть на пьедестале среди ютуберов по js

    • @bublik462
      @bublik462 3 года назад +4

      Очень грамотно объясняет !

    • @demimurych1
      @demimurych1 Год назад

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

  • @ArthurYelkin
    @ArthurYelkin 3 года назад +7

    Я очень рад, что в ютубе появляется всё больше крутых каналов на тему программухи.
    Вот еще +1 в мои подписки.
    Спасибо за ваши видео)

  • @AdequateRussian
    @AdequateRussian 3 года назад +1

    Чел, ты классный! Реально! Почти никогда не пишу такие комментарии, но тебе респект!

  • @2difficult2do
    @2difficult2do Год назад

    Клёво объясняете и юмор сочный! Абстрактные понятия демонстрируемые на конкретных примерах становятся легче для понимания 👍 Вам спасибо! ютубу длинный коммент....

  • @ReAgent003
    @ReAgent003 3 года назад +17

    Спасибо за ролики! 17:24 да, обёртка очень удобная и качественная получилась. Это первое применение reduceRight на практике, которое я увидел))
    Скоро, кстати, в этом отпадёт необходимость потому что в js подвезут оператор удобного чейнинга |>

  • @Triumphator_IV
    @Triumphator_IV 2 года назад +1

    Здравствуйте! Отличная подача материала! Мой вопрос, а где же вторая часть?

  • @ЧеловексЗемли-х2р
    @ЧеловексЗемли-х2р 3 года назад +2

    Благодарю, все по делу.

  • @evgeniymarkitan862
    @evgeniymarkitan862 3 года назад +3

    Спасибо большое за такие видео
    Желаю успехов на ютубе)

  • @ВладиславГригорьев-ы5м

    На функциях высшего порядка мой мозг поплыл. Ну что ж, будем разбираться)

  • @ЧеловексТопором
    @ЧеловексТопором Год назад +1

    Императивный подход отвечает на вопрос как это делать?
    Декларативный подход отвечает на вопрос что делать?
    Но всегда помни, что под капотом любого декларативного подхода лежит императивный.

  • @РоманГирич-з5ш
    @РоманГирич-з5ш 2 года назад +1

    классный видос, хорошая подача и монтаж, спасибо

  • @EugeneChe-81
    @EugeneChe-81 3 года назад

    Дружище. Продолжай! Формат заходит на отлично!

  • @АндрійШвайка
    @АндрійШвайка 3 года назад +1

    Привет автор. Можешь объяснить про столбец "Нет состояниям", который есть на 11:10?

  • @dobermanpharaoh7567
    @dobermanpharaoh7567 2 года назад

    Наконец-то мне замыкания стали понятными!!! супер спасибо

  • @sonkn1ght455
    @sonkn1ght455 3 года назад +10

    Отлично) Но оч не хватило в части про каррирование фразы про частичное применение. Та функция которая запомнила дату например.

  • @ЗенкинВладислав-ы8в
    @ЗенкинВладислав-ы8в 2 года назад +1

    Черт побери, мало того, что материал структурированный, осознанный и грамотно поданный, так еще и видео ряды и вставки радуют глаз. Откуда ты их берешь?

  • @romanroman4308
    @romanroman4308 3 года назад +2

    Спасибо за контент, жду вторую часть

  • @TimurShemsedinov
    @TimurShemsedinov 3 года назад +9

    Тимур одобряет, очень хорошо сделал

    • @Howtogoit
      @Howtogoit  3 года назад

      Спасибо Тимур! У тебя тоже классный канал!

    • @TimurShemsedinov
      @TimurShemsedinov 3 года назад

      @@Howtogoit но, говорят, непонятный)

  • @DenisB-d5f
    @DenisB-d5f 3 года назад +1

    5:35 - Петька и Василий Иванович

  • @snatvb
    @snatvb 3 года назад +16

    то что ты назвал сайдэффектом - им не является, это называние недетерминированная функция, то есть функция, которая работает непредсказуемо в зависимости от окружающих условий
    сайд эффект - это наоборот, влияние на окружение, то есть например, если твоя функция будет детерминированной(то есть всегда при вызове с теми же аргументами, возвращать один и тот же результат), но будет писать в лог или менять какие-то глобальные переменные, отсылать что-то на сервер - это и будет сайд-эффектом :)
    ps сам из FE и обожаю фп, юзаю rescript, советую попробовать)

    • @paul_wiggin
      @paul_wiggin 3 года назад +1

      маслята схавают

    • @interhin
      @interhin 3 года назад

      При этом в слух он проговорил правильное определение, там только на картинке косяк.

    • @Howtogoit
      @Howtogoit  3 года назад +2

      Спасибо огромное тебе! Я действительно допустил ошибку на монтаже и мне очень стыдно сейчас!
      Про детерменированность тоже классное замечание.
      Я обязательно в следующем выпуске про фп расскажу про свой косяк. Ещё раз спасибо!

    • @snatvb
      @snatvb 3 года назад

      @@Howtogoit ничего страшного, все мы ошибаемся :) в любом случае это полезное видео

    • @alexpipin3693
      @alexpipin3693 3 года назад

      не много разобью вашу уверенность в себе, не результат возвращать а сигнатуру

  • @devope
    @devope Год назад

    3:58 В примере слева должно быть `return ++number`

  • @nikto5878
    @nikto5878 3 года назад +1

    Благодарю за контент

  • @AibekSadraliev
    @AibekSadraliev Год назад +1

    Привет!
    Спасибо за полезный контент!
    Подскажите пожалуйста, когда ждать вторую часть про ФП ?)

  • @Slavec5
    @Slavec5 3 года назад

    Уроки кайф, на чиле на расслабоне рассказываешь крутые технические моменты

  • @МаксимСоловьев-с9н

    Ооочень годный видос🔥🔥🔥

  • @aktotuttttt
    @aktotuttttt 3 года назад +3

    Годный контент, спасибо

  • @pavel.arepev
    @pavel.arepev Год назад

    Спасибо
    Вы мощь

  • @volodimiryemshyn715
    @volodimiryemshyn715 3 года назад +6

    Отлично, правда было слишком быстро :) Теперь пойду ломать голову своим коллегам :)

    • @Howtogoit
      @Howtogoit  3 года назад

      Пожалей ребят, они не виноваты =) Да возможно где-то я излишне ускорялся, хотел влезть в формат 20-ти минут

  • @DerTschelovek
    @DerTschelovek 3 года назад +2

    Большое спаибо за ролик. Монтаж - кайф. видеоряд изумителен)

  • @ТатьянаДжанаева-ю4з

    вив лав фром май харт! бест оф ве бест! Если серьезно: просто супер доходчиво! Крайне замечательно!))))

    • @Howtogoit
      @Howtogoit  3 года назад

      Мой любимый Мутко!) Даже не хватает его сейчас!
      Спасибо =)

  • @АлександрСудейченко-ф3н

    4:14 . Есть проблема. Функция не инкрементирует переменную, а просто прибовляет 1.
    Если я вижу функцию increment(var). Я ожидаю что var будет больше на единицу, а не функиция вернет мне var +1;
    В таком случае функция должна называться getPlusOne(var).
    Очень плохой пример...

    • @FrameMuse
      @FrameMuse 2 года назад

      Согласен, и вообще, видео довольно сильно вводит в заблуждение на счёт всех этих тем, лучше курить мануал по всем этим темам и обучаться по этапно, чем слушать супер сокращённую интерпритацию. А это видео скорее просто развлекательное чем обучающие.

  • @mamba-pc8xv
    @mamba-pc8xv 3 года назад

    люблю ютуб за эту рекомендацию. очень годный контент на этом канале.

  • @ПавелВасильев-ц4м
    @ПавелВасильев-ц4м 3 года назад

    Очень крутой видос. С нетерпением жду продолжение.

  • @АртемийКолотов-з4ь

    Экстримцоде отлично сказали про императивность/декларативность, а именно:
    Если мы детали прячем из одной функции в другие, мы все равно в императивном ключе описываем каждый шаг)

  • @zeOnni
    @zeOnni 3 года назад +3

    Пример с чаем в декларативном виде не совсем верный. Скорее это будет как-то так.
    заваренный чай это опущенный в кипяток пакетик с зеленым чаем, где кипяток это вода разогретая до 100 градусов в чайнике

  • @neyasbltb
    @neyasbltb 3 года назад +3

    Отличная подача, так дежать!

    • @Howtogoit
      @Howtogoit  3 года назад

      Благодарю =)

  • @andreygokhan6893
    @andreygokhan6893 3 года назад +5

    Спасибо за великолепную подачу полезного материала.
    Мне кажется что, интуитивно понятней когда в compose функции передаются в том порядке в котором они отрабатывают и когда используется reduce, а не reduceRight. Мы же чейним вызовы по порядку: вначале - первая, в конце - последняя, то есть слева - направо и сверху - вниз. В противном случае можно поломать себе мозг простым вписыванием аргументов, описывая действие от конца к началу. Дело в том, что из книг я вынес именно ту реализацию compose, которую считаю понятной. Но время от времени в ютубе натыкаюсь на такую как в видео и хотел бы понять, в чём смысл перевёрнутого compose?

    • @КонстантинБобровский-с4ы
      @КонстантинБобровский-с4ы 3 года назад +1

      Я предполагаю что это идёт от хода выполнения вложенных функций, то есть сначала выполняеться самая вложенная(правая) и идёт налево.

    • @andreygokhan6893
      @andreygokhan6893 3 года назад

      @@КонстантинБобровский-с4ы Да. Если нагородить ад вложенных вызовов, то внимательный взгляд может заметить пространственное смещение первого вызова вправо. Но это только кажется. На самом деле первый вызов уходит куда-то туда, в глубину экрана, что заставляет нас реализовать позицию "сзади к переду"

    • @andreygokhan6893
      @andreygokhan6893 3 года назад

      На мой вопрос ответил Григорий Бизюкин в видео про фун-ое пр-е, где объяснил разницу между pipe и compose

    • @Howtogoit
      @Howtogoit  3 года назад +2

      @@andreygokhan6893 Да прости, я тоже хотел ответить. Очень хороший вопрос!
      Действительно есть противоположность для compose - pipe
      dev.to/benlesh/a-simple-explanation-of-functional-pipe-in-javascript-2hbj
      Про пайпы я хотел рассказать в серии про Реактивное программирование

    • @alexpipin3693
      @alexpipin3693 3 года назад

      паходу вы не поняли основную идею композиции, идея со стоит в том что бы передать данные по цепочке обратно управляющей функции, так как функции первые в цепочке могу стать управляющими в случае нужды, нельзя просто передавать аргументы "вперед", так как идея в том что бы вернуть измененные данные обратно, а каждая новая, в цепочке добавляет изменяемости, наоборот это очень удобно, когда с конца, так же не забываем по Y комбинаторы, которые разбивают нашу цепочку, на мелкие композиции
      советую вернутся и ещё раз прочитать книги и только теперь внимательно, так как в книгах идет именно этот пасыл, а вы обратно тянитесь к императивному стилю...

  • @olezhonnv3215
    @olezhonnv3215 Год назад +2

    Главное - помнить, что под капотом любой декларативщины лежит импративщина! Хахаха)))

  • @SoldierDenny
    @SoldierDenny 3 года назад

    Спасибо за такое шикарное вступление в мир ФП!

  • @nazarnazarenko437
    @nazarnazarenko437 3 года назад

    Просто талант!👏🏻👏🏻👏🏻

  • @lexsxebelphegore5677
    @lexsxebelphegore5677 3 года назад

    Круто! Вот также бы доступно кто изложил, но про монады, функторы, моноиды.

  • @def-any
    @def-any 3 года назад

    Привет! Зашел посмотреть видос из рекомендаций
    Так понравилось обьяснение принципа функционального программирования, что капец
    Но я не нашел следующей части...
    Ждать ли ее?

  • @AquaDiskoteque
    @AquaDiskoteque 2 года назад

    Я бы еще добавил всё-таки 5 столп - ссылочная прозрачность)

  • @woodDacha
    @woodDacha 3 года назад

    Спасибо, очень познавательно!

  • @Ramosok
    @Ramosok 2 года назад

    Супер!!!!

  • @saymemore
    @saymemore 3 года назад +1

    Очень круто объясняешь!
    Лайк, подписка от меня!

  • @alexroman8878
    @alexroman8878 2 года назад

    А то, что в реакте мы работаем со стейтами, - это не считается нарушением принципов фп?

  • @maksimzolotoi3379
    @maksimzolotoi3379 3 года назад

    Классные ролики ) на уровне

  • @AbraKadabra000
    @AbraKadabra000 Год назад

    4:00 постфиксный инкремент вернёт прежнее значение, то есть единицу.

  • @EwKlidstudio
    @EwKlidstudio 3 года назад +4

    Никогда не понимал чем отличается по сути декларативное программирование от императивного. Как по мне все примеры, которые есть в интернете просто демонстрируют декларативный интерфейс просто как использование более абстрактных и высокоуровневых интерфейсов (типо не открой холодильник, достань банан, закрой холодильник и дай мне банан, а "хочу банан!"). Какая принципиальная разница то? Ну да, мы на другом уровне абстракции, и что?

    • @borisn879
      @borisn879 3 года назад

      Такие же мысли! В декларативном примере есть императивность, мы указали КАК делать. Асимптотически приближаемся к декларативности. Например, нужно посчитать общую стоимость в Корзине, придется указывать КАК это сделать.

    • @Ryhor1
      @Ryhor1 3 года назад +1

      Имхо, нужно проще: есть повторяющиеся наборы команд, тогда неплохо объеденить их в одну. Вот вам и декларативное программирование 👍
      А то разбирать код, где всё декоративно с дурацкими названиями, и код этих декларативных функций надо искать непонятно где, и эти декларативные используются только один раз... Ну это полный трэш. Тут только один вывод: у этого программиста было очень много лишнего времени, раз он решил так заморочиться.

  • @Rafael-cq4rb
    @Rafael-cq4rb 3 года назад +2

    В целом видео хорошее, но есть ошибка, вызванная недопониманием терминов.
    Чистота функции определяется двумя параметрами:
    1. Детерминированность/идемпотентность, т.е. функция при одинаковом наборе аргументоа всегда возвращает один и тот же результат
    2. Отсутствие побочных эффектов, т.е. функция не модифицирует внешние данные
    На 2:48 функция зависит от внешней переменной, т.е. она не идемпотентна, но сайд эффектов при этом не имеет.
    Ровно поэтому, например, функция Math.random() не чистая.
    Программа, которая состоит только из чистых функций ничего не делает. Поэтому, в том, что программистам платят за сайд эффекты, Владимир Гомонов прав)

    • @alexpipin3693
      @alexpipin3693 3 года назад

      пля вы заипали маслята, если тырите определения, не имея понятия что оно означает, хоть потрудитесь не с вики брать
      "один и тот же результат" - нет пля, не результат не что-то другое, а сигнатуру, передал ты массив, будь добр верни массив, передал строку, дальше додумай..

    • @Rafael-cq4rb
      @Rafael-cq4rb 3 года назад

      @@alexpipin3693 А если функция принимает два аргумента, массив и строку, что по твоей логике она должна вернуть? Если функция принимает массив, она не может вернуть строку? Вот это не чистая функция (arr) => arr.join()? Если функция при одинаковых аргументах возвращает разные значения, она чистая? Вот это чистая функция (num) => num * Math.random()? Научи думоть плез, а то я запутался

  • @olezhonnv3215
    @olezhonnv3215 Год назад +1

    Одна просьба к адептам ФП - пожалуйста, не тяните на фронт клужуру)))

  • @AlexanderOhotnikov
    @AlexanderOhotnikov 3 года назад +2

    Отличный и качественный контент! Продолжай в том же духе! )

  • @iliagroshev4780
    @iliagroshev4780 3 года назад +1

    Спасибо тебе за ролики, все отлично)
    Не будет роликов про Vue? Очень хотелось бы

    • @Howtogoit
      @Howtogoit  3 года назад

      Даа, подумываю что можно снять по vue)

  • @dima__rx5fw3rm1n
    @dima__rx5fw3rm1n 8 дней назад

    7:54 ну что же вы? Кирилл вернёт ошибку typeof undefined 😅
    Зато декларативный подход) ну или строкой "Sam idi i nalej!"

  • @vmolo4ke
    @vmolo4ke 3 года назад

    Кучу раз в рекомендациях этот канал показывал мне Ютуб, пропускал. Теперь жалею что потратил время не на твои видео)(

  • @АлексейЧиликиди
    @АлексейЧиликиди 3 года назад

    ПСасибо, супер инфа

  • @ДенисСавка-ш6ц
    @ДенисСавка-ш6ц 3 года назад

    це було чудово

  • @suslikest3708
    @suslikest3708 3 года назад

    Ну это точно лайк:)

  • @olehy5000
    @olehy5000 3 года назад

    Спасибо! Полезный контент

  • @konstantinMonty
    @konstantinMonty 3 года назад +8

    Вот честно, не дай бог чтобы все это начали писать в проектах. Так как это просто будет жопаболь для других прогеров. Пиши императивно добавляя декларативность немного, декомпозируй функции и называй их правильно и читаться будет легко, как книга и мозг и глаза в целости будут. Да декларативщена короче, но зачастую хрен поймешь что внутри твориться, особенно если ее писал какой нить дятел который переменные называет одной буквой.

  • @ЕвгенийКраев-я2ж
    @ЕвгенийКраев-я2ж 3 года назад +1

    А теперь давай про монады и функторы

  • @310384Alex
    @310384Alex 3 года назад +1

    Мда, 20 лет пишу на вэб, 20 лет его учу, каждый пример который я видел можно записать кучей способов и каждый будет иметь свою изюминку. Видео отличное, за объяснение лайк. Теперь надо подождать и посмотреть как все это добро приживется на практике, как оно пройдет испытание временем.

  • @singlebw4065
    @singlebw4065 3 года назад

    может я чë-то не понимаю, но с чистыми функциями не добиться иногда нужного результата и приходиться заводить внешние переменные

  • @meidro_
    @meidro_ 2 года назад

    8:27 метод sort с такой callback функцией сортирует элементы по возрастанию, поэтому первыми будут самые "бедные" люди

  • @samolevich
    @samolevich 2 года назад

    Астанавитес! Столько инфы в момент времени - это больно!
    Я забыл стоп-слово

  • @oleksandrtolstoi5468
    @oleksandrtolstoi5468 3 года назад +1

    Огромная благодарность вам за ваши труды, нравится как и сам материал так и подача - все в ваших роликах безумно полезно!
    P.S. Но вот лично мне эти мультяшные вставки не очень нравятся, они отвлекают внимание, я бы их убрал)

  • @memocity_ai
    @memocity_ai 3 года назад

    5:40 конечно! моя самая любимая серия квестов... Петька и Василий Иванович (он же ВИЧ )

    • @Howtogoit
      @Howtogoit  3 года назад

      Ооо даа) У меня с ним детство ассоциируется

  • @majes96
    @majes96 3 года назад

    спасибо, очень полезно)

  • @AquaDiskoteque
    @AquaDiskoteque 2 года назад

    Давай вторую, часть про монады Maybe \ IO \ Either и комбинаторы с апликаторами и про лифт не забудь) и генераторы с рекурсиями для асинхронки) асинхронка самое то

    • @olezhonnv3215
      @olezhonnv3215 Год назад +1

      Пишешь фронт на кложуре?

    • @olezhonnv3215
      @olezhonnv3215 Год назад +1

      Иди на Лиспе программируй)))

  • @maxchuhryaev9936
    @maxchuhryaev9936 3 года назад +4

    Object.assign и spread создают копию только верхнего уровня свойств. А дочерние передаются по ссылке, что ни коим образом не гарантирует иммутабельность.
    Чтобы честно скопировать, не обойтись без рекурсивного копирования.
    А если объект неприлично огромен, копирование будет не эффективным и нужно применить другую технику.
    В общем, это я к тому, что наш мир не идеален )
    Не всё так просто, как в книжке пишут )

    • @Howtogoit
      @Howtogoit  3 года назад +3

      Даа, только на этот случай существует рекомендация в функциях работать с плоскими объектами. То есть работать с одним уровнем глубины.
      Нужно изменить что-то во вложенном объекте - пора идти в другую функцию.
      Применение deepCopy - это плохо с точки зрения оптимизации. Чтобы в одной функции создать один полностью новый объект приходится пройтись по всему дереву свойств. Хотя в подавляющем числе случаев это не нужно

  • @vogeras
    @vogeras 2 года назад

    Смотрю из ванны. Начал чистку с себя.

  • @zerdox4
    @zerdox4 3 года назад

    15:55
    проблема частично решается новым оператором "|>"

  • @olezhonnv3215
    @olezhonnv3215 Год назад +1

    Декларативность на одном уровне абстракции - это императивность на другом.

  • @Hithori
    @Hithori 3 года назад

    6:50 и dart с вопросом: а что нельзя было делать неявные setter'ы для полей... ладно, но я всё равно их буду создавать :)

    • @Howtogoit
      @Howtogoit  3 года назад

      Ради бога =)

  • @kenesaryHan
    @kenesaryHan 2 года назад

    что делать если меня зовут кирил, мне самому делать чай или искать другого кирила?

  • @JohnDoe-jd6vn
    @JohnDoe-jd6vn 2 года назад

    Где-то прочитал классный коммент примерно следующего вида:
    "Что вы прицепились к этой иммутабельности? В Unity, например, где махровый ООП, всё мутируется и перемутируется и только фронтеры вдруг решили, что для двигания кнопко-формы нужна иммутабельность".
    Честно говоря, я тоже не понимаю этой повёрнутости.
    Кто-нибудь, пожалуйста, приведите РЕАЛЬНЫЙ пример, который показывает, что вот тут функция изменяет внешний объект\переменную и это плохо.

  • @ВладимирНетот
    @ВладимирНетот 2 года назад +1

    4:12 - таким образом у вашей красивой функции есть variable shadowing, что тоже не круто

  • @sergeus-kernel
    @sergeus-kernel 3 года назад

    Привет, замечательно рассказываешь, так держать и успехов тебе!) Столкнулся с проблемой в каррировании)) забавная штука, но в консоли твой код при вызове с 2мя параметрами:
    console.log(curriedSum(1)(2));
    результат:
    ƒ (...args2) {
    // Снова вызываем curried, конкатенируя аргументы двух функций
    // console.log(args)
    return curried.apply(this, args.concat(args2));

    undefined
    , а по идее эта тема должна позволять запуск ф-ции с 2мя параметрами? и в чём подвох?!

    • @starwalker.musician
      @starwalker.musician 3 года назад +1

      Возможно что ты-что то не так "перепечатал" )))))))))))))))))))))))))
      const a = curriedSum(1) - должен вернуть функцию ;
      const b = a(2) - ты ожидаешь - результат (значение)! ...а у тебя, снова, возвращается - функция!
      ...не знаю какой у тебя там уровень вложенности, но напрашивается вывод, что твое выражение должно быть сл.:
      console.log(curriedSum(1)(2)( 3 ));

    • @dm.hol.3624
      @dm.hol.3624 3 года назад

      Кнопка со скобкой не отвалилась?

  • @A_A_A182
    @A_A_A182 Год назад

    Почему так хорошо

  • @cijic
    @cijic Год назад

    2:11 Впервые услышал чтобы someNumber прочитали как самнамба) Звучит как танец или кобра)

  • @kai3341
    @kai3341 3 года назад +7

    10:30 -- Буква S в SOLID всё ещё нарушена: функция сортировки также создаёт копию данных
    Вообще смысл рефакторинга в сокращении сложности кода. Результат же чудо-рефакторинга на экране читать сильно сложнее, и вовсе не потому, что он длиннее. Код стал безумно вязким -- он полагается на порядок вызовов. И нет, в таком виде ты НЕ переиспользуешь логику. Ты нагородил одноразовых функций.
    Неужели сами стрелочные функции вынести наружу сложнее? А после их комбинировать в хвост и в гриву?
    Общее замечание к видео -- ты не понимаешь, о чём говоришь. Нахвататься общих слов и комбинировать их в верных грамматических формах могут даже попугаи, но ты же программист, в конце концов.

    • @ablbaltabekov9083
      @ablbaltabekov9083 2 года назад +1

      Согласен с вами. Когда сократили функцию было все супер и понятно (конечно если супер придраться то можно и придраться статические значения в slice) . И оно не выполнял 3 задачи а одну (высчитать топ 10 самых богатых). Многие путают что S в солиде означает что функция должна выполнять только одно действие, но этот принцип совсем другой. S больше относиться больше к модульности и разделению по логике (бизнес логике и реализации, и не только). Но думаю для объяснения текущей темы про функциональное программирование с мини примерчиками хватит. Если разбирать то этот ролик зардулся бы на несколько часов с кучей философии)))

  • @СергейЛеонидовичСвобода

    У меня мозг чуть не взорвался.

  • @sekirogenshiro2210
    @sekirogenshiro2210 3 года назад

    Офигенный

  • @aleksandrkravtsov8727
    @aleksandrkravtsov8727 3 года назад

    что такое сротал?

    • @Howtogoit
      @Howtogoit  3 года назад +1

      Пацаны застебали в одном из прошлых видосов. Я там так сказал throttle. Поэтому решил отсылочку сделать)

  • @hillmytab7032
    @hillmytab7032 3 года назад

    Подписался по совету друга

  • @awenn2015
    @awenn2015 2 года назад

    Спс, на карировании я просто поплыл

  • @starwalker.musician
    @starwalker.musician 3 года назад

    Что-то по поводу чистоты функции half... сложились сомнения! С чистотой вообще очень спорный вопрос... Чистая функция - УНИВЕРСАЛЬНАЯ функция! Когда в ней нет "магических" значений, а есть только реализация операции, ...иначе (в качестве побочного эффекта) гарантированно получаем необходимость создавать + еще одну функцию (например), которая будет делить не на 2, а (скажем) на 3!!!
    function divider( a, b ) {
    return a / b ;
    }
    function multiplier( a, b ) {
    return a * b ;
    }
    function sum( a, b ) {
    return a + b ;
    }
    function calculations( a, b, processor ) {
    return processor( a, b );
    }
    const A = 4 ;
    const B = 2 ;
    const results = {
    div: calculations( A, B, divider ),
    inc: calculations( A, B, multiplier ),
    sum: calculations( A, B, sum )
    }

  • @Hithori
    @Hithori 3 года назад

    Когда прочитал название первой части видео: "Пролог", уже в холодный пот бросило

    • @Howtogoit
      @Howtogoit  3 года назад +1

      Ну слава богу! С этой целью и писал)

  • @olezhonnv3215
    @olezhonnv3215 3 года назад +3

    Почему жаваскрипт тормозит?
    Тут ответы на этот вопрос!
    ФП - это жалкая попытка представить себе идеальный мир, которая разбивается об жестокую реальность, против которой не попрешь!
    Увы! И ах!

    • @olezhonnv3215
      @olezhonnv3215 3 года назад +3

      И тормоза реакт сайтов бывают очень заметны на старых моб устройствах и компах, где меньше гига ОЗУ.
      На более современных устройствах - тормозов не видно. Но батарею садит быстрее. И это реально так!

  • @dmitryshevchenko2504
    @dmitryshevchenko2504 3 года назад

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

    • @dmitryshevchenko2504
      @dmitryshevchenko2504 3 года назад

      Если функция обращается к некоторому элементу в своей области видимости, который не обладает ссылочной прозрачностью, то и сама функция также не обладает ею. Но такое положение дел можно исправить, переместив непрозрачный элемент в параметр. Несмотря на то что такой шаг перекладывает ответственность на вызывающую функцию, часто можно получить немалую выгоду от создания четко определенных модулей со ссылочной прозрачностью.

  • @Uncaught_in_promise
    @Uncaught_in_promise 3 года назад

    как войти в айти

    • @Howtogoit
      @Howtogoit  3 года назад

      Да я сам не знаю если честно

  • @ТимурГилаури
    @ТимурГилаури 3 года назад +1

    Если функция всегда возвращает одинаковы результат при одних и тех же аргументах - это не значит, что она чистая. Это называется «детерминированность». Под капотом она может влиять на состояние из вне, но возвращать одно и то же. Чистая функция - это та, что не изменяет состояния приложения. И все.

    • @AndreyEricksonGame
      @AndreyEricksonGame 3 года назад

      Такой вопрос. В ФП чистой функцией считается, детерминированная функция без побочных эффектов. А недетерминированная функция тоже имеет право называть себя чистой функцией, при условии, что она не будет изменять внешнее окружение или состояния приложения?

  • @soviertheman5392
    @soviertheman5392 3 года назад

    11:00 вот тут я бы не согласился, это излишняя декларативность, зачем делать алиасы для функций массива в одну строчку, когда можно просто вызвать эту функцию массива. Оно конечно хорошо, когда всё декларативно, но пример излишне декларативен, если бы была какая-то серьёзная логика, то да, а так это излишне. А еще такое было бы не простительно в не инлайн функциях в компилируемых языках, ибо создавало бы лишние фреймы на стэка вызова, а толку от фреймов было бы 0, ибо они просто вызывали бы другую функцию.

    • @Howtogoit
      @Howtogoit  3 года назад +1

      Даа я согласен отчасти. Мой пример конечно очень спорный и зависит от решаемой задачи

    • @alexpipin3693
      @alexpipin3693 3 года назад

      вы просто молодой ещё, так как не нюхали бизнес логику, только не ту где, для вашего проекта это 1+1 = 2, а с кейсами, прессестаими, энтити
      на минутку ангуляр весь в декораторах, а декораторы, это макс уровень деларативности - теперь пойдите насрите им под дверь и живите с этим дальше

  • @spadar1602
    @spadar1602 3 года назад

    Все круто, но вместо каррирования можно юзать генератор

  • @AbraKadabra000
    @AbraKadabra000 3 года назад +7

    Годный(говнокод)(обычно (такое(кодревью(не, проходит))))

    • @Howtogoit
      @Howtogoit  3 года назад +1

      Красиво сделал))

  • @gatrianL
    @gatrianL 3 года назад +1

    Увидеть код на проекте в котором есть чистые функции, это все равно что найти воду в пустыне)))

    • @Howtogoit
      @Howtogoit  3 года назад

      Ну не все же так плохо) Мне кажется чистые функции наоборот более менее все научились использовать