React JS #15 Контекст (React Context)

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

КОМЕНТАРІ • 105

  • @stickpunx9344
    @stickpunx9344 5 років тому +8

    Четкие уроки! Круто что рассказываете все лайфхаки, которые не объясняют другие)

    • @YauhenKavalchuk
      @YauhenKavalchuk  5 років тому

      Спасибо большое за отзыв!

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

    Этот материал здорово помог понять, что есть контекст и как его в реакте юзать )

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

    Спасибо за урок. Все четко и понятно!

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

    наконец-то я нашёл норм видос по useContext, спасибо

  • @rasim.ismayilov
    @rasim.ismayilov Рік тому

    Дай вам Бог здоровья добрый человек)

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

    Этот канал - просто о сложном

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

    Блин! Это лучший урок по контексту. Кучу других пересмотрел и нихрена не понял. Здесь на пальцах!

  • @Alex_Delina
    @Alex_Delina 5 років тому +3

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

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

    Здравствуйте. Поясните пожалуйста (на счетчике видео 6:54) - Если мы в 32й строке value присваиваем стрингу. То почему мы в строке 21 используем title а не value... и почему. Спасибо

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

      Потому что внутри consumer в функции, я переопределил имя с value на title)

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

      @@YauhenKavalchuk а где про этот момент можно найти информацию. Может где то в доках?

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

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

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

    Я очень благодарен за этот видеоурок. 🤝 Он был настолько понятным и легким в усвоении. 🧩

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

    Спасибо! Четко и лаконично! Straight to the point!!!! Respect!

  • @aysommer
    @aysommer 5 років тому +1

    Отличное объяснение, спасибо.

  • @suvacodemorcego
    @suvacodemorcego 5 років тому

    Я бразилец и не могу писать на португальском, но ваше видео мне помогло !!! Спасибо !!!
    Sou brasileiro e nao consegui conteudo em portugues, mas seu video conseguiu me ajudar !!! Obrigado !!!

    • @YauhenKavalchuk
      @YauhenKavalchuk  5 років тому

      It is nice to hear it. I hope you know English!) Thanks!

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

    Спасибо!

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

    Отличный пример 👍

  • @SageMindWhisper
    @SageMindWhisper 6 років тому +12

    Штука прикольная, но на практике юзается не очень часто. В частности из-за того, что все привыкли к редаксу

  • @TORREScs
    @TORREScs 5 років тому +1

    Спасибо! отлично

  • @mokkamokka4097
    @mokkamokka4097 6 років тому

    Снова огонь, спасибо!

  • @alex330k47
    @alex330k47 6 років тому +7

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

    • @YauhenKavalchuk
      @YauhenKavalchuk  6 років тому

      Спасибо большое за подробный отзыв!

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

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

  • @dmitryivanov3200
    @dmitryivanov3200 5 років тому

    Супер!!! Молодец!

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

    Спасибо ,

  • @AlBert-ks4xq
    @AlBert-ks4xq 2 роки тому

    Отлично объяснил. Минимум воды

  • @Мишаня-ю9б
    @Мишаня-ю9б 2 роки тому

    Идеально подойдет для вхождения в тему Context, но потом лучше почитать официальную документацию в React тк многое опущено.

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

      В уроках, к сожалению, всё не расскажешь...

  • @ВиталийЯнковский-г2м

    Подскажите пожалуйста, если мы присваиваем результат вызова функции createContext в переменную TitleContext и далее используем в компонентах TitleContext.Provider и TitleContext.Consumer, то как быть с модульностью? Как получить доступ к переменной TitleContext, если вложенные компоненты расположены в разных файлах? Нужно создать эту переменную в отдельном файле, а потом импортировать её в нужные файлы?

    • @YauhenKavalchuk
      @YauhenKavalchuk  6 років тому

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

    • @ВиталийЯнковский-г2м
      @ВиталийЯнковский-г2м 6 років тому

      @@YauhenKavalchuk Спасибо! :)

    • @YauhenKavalchuk
      @YauhenKavalchuk  6 років тому

      Пожалуйста)

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

    А если, например, на втором уровне тоже пробрасывается контекст, он не перезапишется? Как его использовать правильно? Тоже врапнуть в ещё один контекст консумер?

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

      А зачем вам нужно 2 контекста? Почему не определить все нужные данные в одном? Подход, как в Redux - стор для хранения всего

  • @jenyaspace
    @jenyaspace 6 років тому +1

    Можно ли делать тоже самое только наоборот, снизу вверх по иерархии компонентов?

    • @YauhenKavalchuk
      @YauhenKavalchuk  6 років тому

      Нет, данные всегда идут сверху вниз, т.е. от родителя к ребёнку. Это однонаправленный поток данных, точно так же, как и в Redux.

    • @jenyaspace
      @jenyaspace 6 років тому

      @@YauhenKavalchuk Но как тогда можно что-то сделать в родителе если что-то меняется в ребенке

    • @YauhenKavalchuk
      @YauhenKavalchuk  6 років тому +1

      Для этого есть или стейт, или контекст. Эти данные вы пробрасываете в ребёнка в виде пропсов, или контекста. Там их меняете, родитель видит изменения в объекте за которым он наблюдает и обновляется.

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

    А как возможно предавать методы компонента-родителя дальше по дереву через контекст? У меня получилось предать метод, добавив вот такое поле в объект контекста 'clickHandler: () => this.handleClick.call()'. Хотелось бы узнать, есть ли альтернативная запись для этого

  • @ineptDev
    @ineptDev 5 років тому

    Функция внутри TitleContext.Consumer выступает как компонент внутри, без имени, или как? Потому как здесь нету вызова этой анонимной функции... Или я чего-то недопонял?

    • @YauhenKavalchuk
      @YauhenKavalchuk  5 років тому

      На текущий момент синтаксис "контекста" чуть упростился. Можете посмотреть плейлист React podcast, там есть пример

    • @ineptDev
      @ineptDev 5 років тому

      @@YauhenKavalchuk окей, спасибо.

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

    👍

  • @anastasiiam5429
    @anastasiiam5429 5 років тому

    Спасибо за видео! А можно через этот метод передавать данные от детей к родителю?

    • @YauhenKavalchuk
      @YauhenKavalchuk  5 років тому

      Можно. Фактически, это нативная реализация Redux

    • @anastasiiam5429
      @anastasiiam5429 5 років тому

      @@YauhenKavalchuk Можно реализовать передачу на прямую или всеравно использовать коллбек?

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

    Я вообще не понял прикола существования createContext. С таким же успехом можно создать файл storeContext создать там обычный объект, импортировать его в index положить в него нужные данные, импортировать в нужный компонент и получить эти данные. Работает в точности так же. При всём при этом оборачивать ничего не нужно ни в какие Provider и Consumer. А создать в отдельном файле чтоб не было подключений import export в обе стороны. А ещё использовав Consumer мы не имеем доступа к значениям выше методы render в классах, приходиться использовать специальное свойство класса static contextType = Context. после можем обращаться к объекту context. Но как я и сказал обычный объект это спокойно решает.

  • @Zluka366
    @Zluka366 6 років тому

    спасибо!

  • @ШураБосс
    @ШураБосс 6 років тому

    Подскажите, я так понимаю контекст - это замена Redux на уровне самой библиотеки?

    • @YauhenKavalchuk
      @YauhenKavalchuk  6 років тому

      Ну в целом, да. По ключевой роли - очень похоже. Хотя думаю, для действительно больших приложений не применимо.

  • @jenyaspace
    @jenyaspace 6 років тому

    что означает синтаксис {title => {title}}?
    а как можно сделать через контекст если надо от родителя к ребенку просто передать булевое значение что типа ребенок используется в этом родителе или нет?

    • @YauhenKavalchuk
      @YauhenKavalchuk  6 років тому

      Это синтаксис стрелочной функции: () => {};
      Если передать от родителя к ребёнку, то контекст вам вообще не нужен, достаточно пропсов.
      Контекст используется, когда значениея нужно передавать через несколько уровней, минуя эти уровни.

    • @jenyaspace
      @jenyaspace 6 років тому

      @@YauhenKavalchuk Спасибо, так в том то и дело что компонент содержит еще много уровней к ребенку, поэтому не хотелось бы использовать пропсы

    • @YauhenKavalchuk
      @YauhenKavalchuk  6 років тому

      Я понял, просто звучало по другому, но не суть. Попробуйте повторить пример как в виде, просто заменить значение со строчного на булевое.

  • @kefyru
    @kefyru 5 років тому

    Во первых, БОЛЬШОЕ ЧЕЛОВЕЧЕСКОЕ СПАСИБО за твои уроки, очень понятно и доходчиво... На них освоил js с нуля, затем react, mobx... пишу вот приложеньку на react-native... Есть вопросец: использую react.context (static contextType = ... ; const context = this.context...). Все замечательно работает, разобрался (с твоей помощью), но постоянно мозолит глаза (в WebStorm) - this.context перечеркнуто и подсвечивает "Deprecated symbol used...". Пакеты: react@16.8.3, @types/react@16.8.22... Уже весь гугл перешерстил - ничего не нашел. Жить конечно можно, но раздражает. Если есть идеи как победить буду спасибо)

    • @YauhenKavalchuk
      @YauhenKavalchuk  5 років тому

      Спасибо за отзыв. Видимо ругается на то, что вы используете устаревший синтаксис context. На канале есть плейлист react videocast там я рассказываю о новом синтаксисе контекста. Если проще, то теперь используется статическое свойство

    • @kefyru
      @kefyru 5 років тому

      @@YauhenKavalchuk Пересмотрел видеокаст... Я так и делаю: в своем классе добавляю [static contextType = myContext;] а в рендере [const _context = this.context;]. Работать работает, контекст передается и в нем лежит именно то что нужно, но в редакторе (WebStorm) подсвечивает что deprecated... Может я как то неправильно typescript настроил? Или чего то не понимаю...

    • @YauhenKavalchuk
      @YauhenKavalchuk  5 років тому

      Тогда, возможно, проблемы в настройках

  • @jenyaspace
    @jenyaspace 6 років тому

    Но что делать если компоненты находятся в разных файлах, родитель и ребенок, как тогда настраивать контекст?

    • @YauhenKavalchuk
      @YauhenKavalchuk  6 років тому

      Подключать библиотеку для контроля за состояние Redux, MobX. Или всё-равно находить родителя и оборачивать компонент

  • @p_levin
    @p_levin 6 років тому

    Разве нельзя импорт сделать с передачей необходимых state или методов?, прослушка событий?
    Это все выглядит довольно грязно и это норма в React?, где красота)?

    • @YauhenKavalchuk
      @YauhenKavalchuk  6 років тому

      Контекст - это новое API, которое было добавлено. С версией 16.6 синтаксис немного упростился - нету лишних обёрток. А вообще импорт стейта и методов - это не по канонам React, скажем так).
      Но в целом API очень полезное, если вы работали с Реакт длительно время, то оно действительно помогает решить Props Drilling, а этого, раньше, и не хватало)

  • @МаксимНырков-у6г
    @МаксимНырков-у6г 5 років тому +1

    ну это конечно прикольно. Я бы сказал в самом начале пути меня это прокидывание пропсов через компоненты сильно бесило. Отличная замена)

    • @YauhenKavalchuk
      @YauhenKavalchuk  5 років тому

      Благодаря этой идее, на некоторых проектах начинают отказываться от Redux

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

    А что мешает создать банальный объект и в него положить данные?
    А там, где нужно, эти данные из объекта считать.
    По сути, в этом уроке показано сохранение данных в контекст через Провайдер, и извлечение данных через Консумер.
    Такой себе наворот поверх обычного объекта, который может то же самое. Но тут еще провайдер, консумер, функция для извлечения.
    Ну мудрят хлопцы - им реально нечем там заняться в Фейсбуке, или где там тот Реакт делают :-)

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

      Скорее всего, есть юзекейсы, где нужен именно такой контекст, а простой объект не подойдет.
      Мне просто Реакт заходит через силу, потому что по работе надо разобраться.
      Постоянно ищу в нем недостатки.

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

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

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

      крик души

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

      Уж как есть

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

    useContext

  • @iGotton
    @iGotton 5 років тому

    +

  • @RagazzoKZ
    @RagazzoKZ 5 років тому

    На react context api можно сделать свой redux. А этот сам redux выкинуть, нах он нужен, он ужасен

    • @YauhenKavalchuk
      @YauhenKavalchuk  5 років тому

      В целом это возможно, но я знаю осень много людей, которые бы поспорили с вами!

    • @ЕвгенийЖ-н6м
      @ЕвгенийЖ-н6м 4 роки тому

      В redux при изменении стор перерендривается только те компоненты которые подписаны на него, а контекста получается рендрится все начиная с корневого компонента.

  • @НурсултанРамазанов-е3ь
    @НурсултанРамазанов-е3ь 11 місяців тому

    Спасибо!