САМЫЙ ПОЛЕЗНЫЙ хук для ОПТИМИЗАЦИЙ в React | React Hooks

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

КОМЕНТАРІ • 125

  • @2difficult2do
    @2difficult2do Рік тому +4

    Очень хорошая подача информации, в темпе и ничего лишнего. Спасибо, было интересно посмотреть.

  • @701block
    @701block Рік тому +11

    Такое ощущение,что подача изменилась,стала такой размеренной и более спокойной.

    • @ayub_begimkulov
      @ayub_begimkulov  Рік тому +2

      Надеюсь это не только ощущение)

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

      @@ayub_begimkulov тоже обратил на это внимание. Видео очень полезное, спасибо!

    • @АлександрСадыков-ъ8щ
      @АлександрСадыков-ъ8щ Рік тому +4

      В любом случае нужно скорость 0.75 ставить, что бы успевать улавливать мысль)

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

      Очень сложно вообще понимать о чем речь все равно

  • @alekseyleha9942
    @alekseyleha9942 Рік тому +2

    Спасибо, Аюб. Буквально в пятницу колхозил свой useWindowEvent, но немного спотыкнулся, а тут твоя неотложная помощь, очень к месту)

  • @роматарасов-о8л
    @роматарасов-о8л Рік тому +5

    очень актуальное видео
    уверен что многие использовали реф только для доступа к отрендеренным элементам
    примеры хорошие и реалистичные

  • @НикитаШевченко-ы8я

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

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

      Это классно, что применяешь информацию на практике. Спасибо за фидбэк!

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

    👍👍👍, я столько смотрел предыдущий плейлист, что в этот раз всё понял с первого раза😂😂😂

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

    Очень крутой и полезный контент, не останавливайся, подписота будет расти :)

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

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

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

      Можно просто репу склонить и там поиграться, как вариант.

  • @АнатолийГорбов-о1ь

    Очень крутое видео!! Спасибо!

  • @Victor-il9gm
    @Victor-il9gm Рік тому +1

    огонь контент, спасибо!

  • @НикитаШевченко-ы8я

    Очень полезно. Спасибо) И качество подачи сильно выросло.

  • @Алекс-р9ю6х
    @Алекс-р9ю6х Рік тому

    Спасибо за видео ! ОЧень информативно) Только есть один вопрос, не совсем понял почему на 18 минуте мы возвращаем реф через apply. Есть какие-то кейсы, где колбэк может случайно взять какой-то this ?

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

    Видео как всегда топ, давай ещё!)

  • @МаксимИсаев-ъ5о
    @МаксимИсаев-ъ5о Рік тому +1

    Интересный ролик! Моё почтение 🤝

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

    Недавно наткнулся на проблему с собственноручно написанным дебоунсом. Суть в том, что колбэк в дебаунсе постоянно подхватывал значения стэйта предыдущего рендера. Пришлось лезть в библиотеку use denounce и смотреть как ребята решили эту проблему. Долго не мог и там понять, а оказалось нужно было использовать реф😂😂. Спасибо за глубокий контент!!! ❤

  • @ПетрПетров-ж9е
    @ПетрПетров-ж9е Рік тому +2

    Большое спасибо за твои видео. У меня возник вопрос по поводу хука useIsMounted. Почему в нем не использовать useLayoutEffect?

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

      Можно и useLayoutEffect. Разницы нету. Просто обычно асинхронные экшены в useEffect запускают, поэтому как-то разницы у меня на практике и не было. Спасибо за фидбэк!

    • @ПетрПетров-ж9е
      @ПетрПетров-ж9е Рік тому

      ​@@ayub_begimkulov Спасибо за быстрый ответ. Не понимание что useIsMounted нужен только для асинхронных функций рождает дурацкие вопросы)))

    • @ПетрПетров-ж9е
      @ПетрПетров-ж9е Рік тому

      Потратил на поиск проблемы пол дня и понял что useEffect это оптимальное решение.
      1. Если в хуке использовать useEffect а в компоненте useLayoutEffect то работать не будет потому что очередь вызовов. useLayoutEffect решает всем известную проблему с мерцанием(это когда мы внутри useEffect меняем состояние и отображаем его внутри компонента), но мерцание это про синхронный код а в нашем примере асинхронный код. Придумать кейса где в компоненте нам нужен useIsMounted внутри useLayoutEffect я не смог.(тут победа за useEffect)
      2. Это косвенно относится к react. useLayoutEffect не работает в nextjs и выбрасывает исключение для обхода этой проблемы используют useIsomorphicLayoutEffect.(тут тоже победа за useEffect)

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

    Просто огонь🔥

  • @v.demchenko
    @v.demchenko Рік тому +1

    Раньше не понимал а сейчас как понял

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

    спасибо!👏👍

  • @kirillpodolinniy309
    @kirillpodolinniy309 Рік тому +5

    Аюб, добрый вечер) Спасибо большое за видео)
    Есть вопрос!
    В доке реакта такая информация написанна про useRef
    "Do not write or read ref.current during rendering.
    React expects that the body of your component behaves like a pure function:
    If the inputs (props, state, and context) are the same, it should return exactly the same JSX.
    Calling it in a different order or with different arguments should not affect the results of other calls.
    Reading or writing a ref during rendering breaks these expectations."
    А мы в первом примере делаем это во время рендера, где тут правда и как разобраться? Спасибо)

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

      Все верно, в рендере не надо обновлять реф. Я просто так сделал в начале для простоты.
      Если ты посмотришь видео дальше - то я объясняю этот момент, когда мы разбираем хук useLatest. Ну и статья есть о том, почему так не надо делать в описании.

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

      @@ayub_begimkulov А на сколько в целом актуален этот пример со states для inputs и хранением value из inputs в ref? Почему в таких кейсах не использовать useDebounce хук или относительно новый useDefferedValue из react

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

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

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

    Я кайфанул🔥

  • @ЕгорЛазука-й1э
    @ЕгорЛазука-й1э Рік тому +1

    Спасибо за видео.
    Объясни пожалуйста, в чём отличие useLatest от usePrevious в видео

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

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

    • @ЕгорЛазука-й1э
      @ЕгорЛазука-й1э Рік тому

      Понял, спасибо@@ayub_begimkulov

  • @maratgrigoryan1674
    @maratgrigoryan1674 9 місяців тому

    Подскажите пожалуйста, почему в массив зависимостей для useLayoutEffect в хуке useLatest не добавить value? Это сделано специально для каких-то кейсов?

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

    комментарий в поддержку канала

  • @lord8360
    @lord8360 Рік тому +9

    Самое простое действие для оптимизации, это вынести логику из компонента 😊

    • @ayub_begimkulov
      @ayub_begimkulov  Рік тому +2

      Это не всегда возможно, но решение хорошее.

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

    Сильный Аюб

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

    Хороший контент, раз такое дело, мб про Next серию роликом))

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

      Можно подумать, добавлю себе в список.

  • @kolyunchikable
    @kolyunchikable Рік тому +13

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

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

      Принял, над речью еще работаю, согласен, что не идеал. Спасибо за фидбэк!

    • @Мояшарага-ъ2ж
      @Мояшарага-ъ2ж Рік тому +2

      @@ayub_begimkulov мне наоброт кажется так лучше. В старых видосах говорил медленно, тихо и часто запинался. Сейчас все быстро, четко и громко.

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

      ты можешь замедлить видео

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

      @@xice111 я так и делал иногда)

    • @v.demchenko
      @v.demchenko Рік тому

      @@xice111 если тебе медленно ты можешь ускорить видео🤡

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

    Подскажите, пожалуйста, зачем в hook useEvent используется apply, а не просто вызов функции?

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

      Можно и вызов функции. Разница нету. Это больше для того, чтобы spread лишнего избежать.

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

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

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

    Так и не понял зачем в useEvent еще оборачивать в коллбек. Не проще ли в том же рефе держать входную и стабильную выходную функции?

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

      Это нужно для того, чтобы постоянно не писать cb.current() при вызове. А так можно использовать хук useLatest и все. Разница нету, просто для удобства сделано)

  • @ДиалектикаКринжа

    Интересно подойдет ли useEvent для первого примера с handleSubmit и почему useIsMounted использует useEffect, а не useLayoutEffect...

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

      useEvent подойдет конечно же, для useIsMoutned можно и useLayoutEffect использовать. Просто асинхронные действия ты делаешь обычно в useEffect, поэтому обычно он там только нужен будет.

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

      @@ayub_begimkulov тоже когда смотрел подумал про useLayoutEffect, чтобы флаг точно поменялся до начала выполнения всех useEffect

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

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

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

      у меня в формах частенько встречается, но это может быть изз того что я сам неправильно пишу формы=)

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

      @@rustamakhmetyanov4404 Ну если на формах какая-то сложная логика, требующая работы с нативными DOMNode, то вполне возможно, но я достаточно редко пользуюсь неконтролируемыми состояниями

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

      Тут на самом деле все примеры "сферические в вакууме". Так как из реально проекта я один пример буду пол урока объяснять.
      Скорее нужно понять принцип. Бывают случаи, когда у тебя есть четкий флоу, который задумывался реактом - с новым стейтом обновляются все зависимости.
      Однако в кейсе с формой, наш колбэк вообще не был завязан на стейт, ему просто нужен был способ получать его актуальное значение, а сам он вешался на ивент пользователя.
      На самом деле такой флоу зачастую нужен именно с функциями, поэтому и был RFC на useEvent hook.
      А в целом, спасибо за фидбэк. Постараюсь поработать над примерами!

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

      На самом деле многие библиотеки используют подход с uncontrolled формами, так как он более оптимальный для перформанса.

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

    👍👍👍

  • @ИванКораблин-т4ю

    Подскажи пожалуйста какой у тебя шрифт, который на скринах?

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

      На скринах - это те, что с кодом? Если ты про них, то я не знаю названия, дефолтные из VSCode на маке.
      А если про презу - то это Arial)

    • @ИванКораблин-т4ю
      @ИванКораблин-т4ю Рік тому

      @@ayub_begimkulov спасибо

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

    Не знаю почему мой комментарий удалился, напишу снова.
    1. Используй Profiler для наглядности, там лучше всё видно по целому дереву.
    2. Прикладывай Git, чтобы потыкать можно было
    Прекрасное видео

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

      Git приложил в описание, почему то в это раз забыл.
      Вот ссылка:
      github.com/Ayub-Begimkulov/youtube-tutorials/tree/master/react-hooks/lessons/use-ref
      Касательно профайлера - даже не подумал. Спасибо за идею и за комментарий!

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

    Ayub hozir Yandexda ishlayapsizmi

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

      Нет, я уже не работаю в Яндексе.

    • @8lop966
      @8lop966 Рік тому

      @@ayub_begimkulov кстати , интересно было б услышать твою историю как ты попал в яндекс, там вроде тяжело пробиться

  • @ИгорьНово
    @ИгорьНово Рік тому +4

    Очень хочется чтобы Айюб, говорил с паузами между предложениями. Потому что в процессе хочется подумать, о сказанном, а иногда просто не успеваешь 🥺🥺🥺

    • @sharkman6434
      @sharkman6434 Рік тому +2

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

    • @ИгорьНово
      @ИгорьНово Рік тому

      ​@@sharkman6434 а чего сразу не на скорости 2х 😅 ???

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

      @@ИгорьНово на скорсти 2х Минина смотрю он медленее говорит, кстати попробуйте с минина начать и через годика два сюда уже заглянете ))

    • @ИгорьНово
      @ИгорьНово Рік тому

      @@sharkman6434 та минина уже смотрел давно, надо что то более интеллектуальное, и вот Айюб хорош, но только подача, как будто за айюбом кто-то гонится, это немного мешает. Если взять в вример uilbi, то он тоже быстро подаёт информацию, но у него нет именно спешки. И поэтом усваивается отлично.

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

      Над речью надо поработать - споров нету. Активно работаю над этим, надеюсь исправится в ближайших видео. Спасибо за фидбэк!

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

    Уже говорили, что ты знаешь реакт лучше, чем его разрабы?

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

    16:45 В жизни не поверю, что идею Дениса Абрамовича отвергнули😮

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

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

    • @ПетрПетров-ж9е
      @ПетрПетров-ж9е Рік тому

      Просто ты плохо понимаешь суть слова use. Например useТутИдетНазваниеКостыля. Уловил суть?

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

      @@ПетрПетров-ж9е Дэн легенда

    • @ПетрПетров-ж9е
      @ПетрПетров-ж9е Рік тому

      @@just__did__it Проблема не в дэне а в количестве костылей для реакта.

    • @ПетрПетров-ж9е
      @ПетрПетров-ж9е Рік тому

      ​@@just__did__it Хотел промолчать но немогу эта фраза дэн легенда меня все таки сильно зацепила.
      Слушай корпорация зла тратит миллионы долларов чтобы дэн рекламировал реакт и при этом реакт можно скачать в открытом доступе(звучит как благотворительность), думаешь эти парни хорошие и думают о нас? Ответ нет. Корпорация всегда заинтересована в прибыли или уменьшении убытков. Дэн рекламируя реакт дает компании дешевых программистов то есть они не думают о нас они просто хотят получить более дешевую раб силу на галеру))).

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

    *Когда включил god mode для js

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

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

  • @v.demchenko
    @v.demchenko Рік тому

    Прям очнь быстро говоришь. Я думаю было бы лучше сделать несколько видео где ты пишешь сам код и обьясняешь.

  • @простойчеловек-с8к

    Метишь на конкуренцию с ульби по быстроте подачи))
    Материал однозначно не для новичков, а для опытных кодеров, хотя примеры и разбираются на инпутах.

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

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

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

      А если серьезно, то в новых видео вроде этот момент должен по лучше стать. Спасибо за фидбэк!

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

    можно еще быстрее говорить?)

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

      Я слышал, что в ютубе 2х можно поставить)
      А если серьезно, то работаю над речью - постараюсь улучшить этот момент.
      Спасибо за фидбэк!

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

    Инфа полезная, но плохо структурировано, из-за чего воспринимать ну оооочень тяжело

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

    export const useStableCallback = (
    callback: T|undefined
    ): T => {
    const ref = useRef({ callback })
    useLayoutEffect(()=>{
    ref.current.callback = callback
    })
    if (!ref.current.stable) {
    ref.current.stable = ((...p: any[]) => ref.current.callback?.(...p)) as any

    }
    return ref.current.stable!
    }