Лучшие практики по работе с Context API в React приложении

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

КОМЕНТАРІ • 59

  • @sergejserdjukow4859
    @sergejserdjukow4859 5 місяців тому +6

    Магия разработки! 🔥 Пошёл оптимизировать приложения. Спасибо за полезный и годный контент! 👍

  • @liganshow
    @liganshow 5 місяців тому +16

    В целом так и делаем) И приходим к contexts hell) Потому что если какой то модуль имеет немного больше логики, которую мы еще инкапсулируем в кастомные хуки, просто что бы разделить разные части логики в отдельных местах, то получается что у нас много values меняются в не зависимости друг от друга. Я как то писал на React компонент таблицы, и вышел этот компонент большим, много пропсов и тд...Вышло больше 10 контекстов, что бы это происводительно работало.

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

      это все работает да, но такое дрочево ... вместо этих танцев с бубном заюзать тот же mobX и нормально работать

    • @владимиркарпов-т4ъ
      @владимиркарпов-т4ъ 4 місяці тому

      useSignal();
      npm I @preact/signal ->
      передавать куда угодно что угодно, перерисуется только обновлённый

    • @eg0ist_665
      @eg0ist_665 4 місяці тому

      @@владимиркарпов-т4ъ юзаю сейчас jothai и кайфую

  • @victormog
    @victormog 5 місяців тому +6

    Отличный контент и формат!

  • @Roman-kn7kt
    @Roman-kn7kt 5 місяців тому +1

    Михаил вы невероятно крутой учитель !! Спасибо вам !!

  • @deker9296
    @deker9296 5 місяців тому +2

    Спасибо за полезное видео!

  • @bukashkakriper228-ns9pp
    @bukashkakriper228-ns9pp 5 місяців тому +1

    огонь!🔥

  • @DubinArtur
    @DubinArtur 5 місяців тому +2

    Нужно использовать сторы)

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

    спасибо за контент)

  • @АлександрСкиталец-ц7р
    @АлександрСкиталец-ц7р 5 місяців тому +6

    В React 19 не будет вроде как мемоизации? Разделять на два контекста это хорошая идея.

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

      Не в самом Реакте. Это будет отдельный бабел-плагин, опциональный к использованию. Пока он в экспериментальном режиме.

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

    Первый раз такой подход видел в докладе Яндекса. Надеюсь 19 версия с компилятором изменит оптимизацию

  • @shurinskiy
    @shurinskiy 3 місяці тому

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

  • @ОлегНизиёв-р9ж
    @ОлегНизиёв-р9ж 5 місяців тому

    Можно еще сделать видео Redux vs Context. Где, что и когда использовать, какой от этого профит. С удовольствием бы посмотрел !

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

      Смысла в их сравнении нет, ибо это разные технологии.
      Redux - стейт менеджер, задачей которой является хранение и изменение данных приложения.
      Context API - технология в React, созданная для лёгкого обмена данными между компонентами.

  • @Jen13022
    @Jen13022 5 місяців тому +4

    Если вам нужно работать с парочкой модалок и изменять тему - не ставте себе zustand либо ещё какой нибуть стм.Контекста хватит

  • @Алексей-ш8э3л
    @Алексей-ш8э3л 5 місяців тому

    Михаил, здравствуйте! Вы планируете обновлять свой курс по React 18? Вы классно объясняете, хотелось бы у вас поучиться!

    • @mishanep
      @mishanep  5 місяців тому +2

      Мой курс актуален. Чего-то принципиально нового, что бы поменяло подход к разработке, не появилось в 18й версии. Да и в 19й не появится. Добавится несколько новых фишек, но ядро будет тем же.
      Однако планы по обновлению или записи другого курса у меня есть. Нет понимания сроков.

  • @grandmaster-yo-yo
    @grandmaster-yo-yo 3 місяці тому

    Подскажите а зачем делать useMemo на todos, totalTodos? Ведь мы оптимизировали ререндеринг отдельной тудушки за счет контекста экшенов, но todos и totalTodos будут всегда меняться и memo не поможет. Верно?

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

    Михаил,немного не туда вопрос ,но все же: подскажите. У вас было легкое видео по rtk-query. Скажите, есть ли возможность делать ревалидацию запроса только при положительном ответе, а не постоянно (invalidate)

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

      Да, в RTK Query есть возможность настроить ревалидацию кэша только при положительном ответе. Для этого вы можете использовать providesTags и invalidatesTags в комбинации с проверкой статуса ответа.

  • @user-ey2vv1dl3n
    @user-ey2vv1dl3n Місяць тому

    use-context-selector не решает эту проблему?

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

    Есть такая тема с разделением на гетеры/сетеры

  • @g_prgv
    @g_prgv 5 місяців тому +1

    На первом этапе: зачем оборачивать в useCallback, если потом не использовать эти функции как зависимость?

    • @mishanep
      @mishanep  5 місяців тому +2

      По-моему у меня просто линтер не ругался, а обычно в таких случаях линтер требует включить в массив зависимостей всё, что используется внутри хука.

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

    Михаил, что вы думаете про websim ai?
    Спасибо

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

      Никогда про него не слышал.

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

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

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

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

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

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

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

      @@mishanep спасибо. догадались же. разве профессионал такого уровня мог иначе? я так и предположил но усомнился. в итоге сделал через мобикс

  • @nikitashelest5343
    @nikitashelest5343 5 місяців тому +1

    как-то много плясок с бубном, почему во Vue все вроде как работает сразу? нужно пояснение, срочно

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

      потому что во vue мощная и удобная система реактивности и закадровых оптмизаций

  • @codegorian6057
    @codegorian6057 5 місяців тому +1

    Пожалуста сделайте обзор про React 19

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

      Так у меня был уже :) несколько месяцев назад. Называлось Будущее Реакта

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

    Михаил расскажите про зустанд в нексте

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

    А, почему ты в li key не добавил?

    • @mishanep
      @mishanep  5 місяців тому +1

      Потому что не надо. Ключи добавлены на уровне выше, этого Реакту достаточно.

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

      @@mishanep Ok. Я не заметил этого. Берешь к себе джунов на реакт или некст за недорого на удаленку? За менторинг и суп.

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

    иногда бывает что не писать memo гораздо дешевле чем писать memo. Работает ли это так же и здесь?

    • @mishanep
      @mishanep  5 місяців тому +6

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

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

      @@mishanep Согласен

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

    Капец! Работая с Реакт об всей этой оптимизации постоянно нужно думать… Во Vue это уже сделано! Расскажите еще почему useState изменяеться асинхронно? И это большая проблема!!!

    • @rea1m_
      @rea1m_ 3 місяці тому

      Если бы useState работал синхронно твое приложение жутко лагало бы

  • @TeeBKECH
    @TeeBKECH 5 місяців тому +1

    Спасибо за видео! На 13:59 есть оговорка, речь идет про редакс на сколько я понял

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

    спасибо за видео, но все равно ничего не понял

  • @noob_dodger
    @noob_dodger 11 днів тому

    Какой же все-таки React сплошной антипаттерн.

  • @JJohnson-fy9uz
    @JJohnson-fy9uz 5 місяців тому +1

    Зачем вообще использовать контекст? На любом крупном проекте есть стейт менеджер. Контекст годится разве что для пет-проектов 😂

    • @olegsh2888
      @olegsh2888 5 місяців тому +3

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

  • @Alex-Shohet
    @Alex-Shohet 5 місяців тому

    можно перестать грызть кактус и использовать zustand

    • @Jen13022
      @Jen13022 5 місяців тому +2

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

    • @Alex-Shohet
      @Alex-Shohet 5 місяців тому +2

      однако тема полезна тем что перед тем как переходить на что-то лучшее, контекст нужно знать

  • @frontfromsofa
    @frontfromsofa 5 місяців тому +1

    Вывод - отказаться от контекста

    • @CJIu3eHb
      @CJIu3eHb 5 місяців тому +2

      Да это редко кому нужно, сталкивался пару раз на тестовых, хотели именно контекста. Бесила проверка на наличие контекста (если с типизацией), которую здесь спрятали в хук вместе с двумя импортами. Хук - это полезная идея из видео. И не задумывался об оптимизации экшенов, т.е. разделение контекста - вторая полезная идея видео. Но, в целом, конечно - нах такое вообще нужно в обычном проекте. т.к. бойлерплейта чуть ли не больше, чем в старом редаксе.