Учимся использовать useMemo, useCallback и React.memo | подводные камни | JavaScript, React

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

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

  • @Владимир.П-е9о
    @Владимир.П-е9о 2 года назад +17

    Крутая тема, крутое видео!
    Хуки и реакт вообще больная тема для меня, слишком много ошибок в них делают разработчики, причем любого уровня.
    Есть еще проблема про меморизацию компонента с children, про это многие забывают. Если передать обычный jsx в children компонента обернутого в memo, то на каждый рендер будет вызываться createElement для этого children, а createElement каждый раз создает новый объект, из-за чего меморизация ломается и добавляет лишний вред для производительности вычислениями меморизации. Еще в контекст многие любят передавать объект, ломая перф всего приложения одной строчкой.
    Очень круто, что вы поднимаете такие темы.

    • @webelart
      @webelart  2 года назад +6

      Спасибо за комментарий и за дополнение про children. Закрепляю!

    • @sergeys4732
      @sergeys4732 2 года назад +2

      Так объект можно в useMemo завернуть) не ломая перф никакой

    • @Владимир.П-е9о
      @Владимир.П-е9о 2 года назад +1

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

    • @cybersystem5137
      @cybersystem5137 7 месяцев назад

      @@Владимир.П-е9о ога, ну или вынести объект за пределы компоненты и угомониться. Потому что тут он константный.

  • @dr_morpho
    @dr_morpho 2 года назад +23

    Как у вас лампово и на лайте, никакой душноты, успехов вам)

    • @webelart
      @webelart  2 года назад +2

      😘 Спасибо!

    • @theoty-js
      @theoty-js 2 года назад +2

      да, и разбор деталей и погружение в технические моменты, нравится мне изучать React вместе с Еленой и ее эмоциями))) Уникальность и оригинальность чувствуется!

  • @enjoymtx
    @enjoymtx 5 месяцев назад +1

    Какую хорошую вы проделали работу с этим уроком, браво!

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

    Спасибо Елена, заслуженный лайк и подписка)) просмотрел кучу видео на эту тему, но так доходчиво еще никто не объснял

  • @МаксимБондаренко-у3о

    Феминизация слова "компонент" прошла успешно

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

      КомпонентА ❤

    • @АлександрКас-н7з
      @АлександрКас-н7з 4 месяца назад

      ахахахах)мне тоже слух прям режет)

    • @dm.hol.3624
      @dm.hol.3624 Месяц назад

      @@АлександрКас-н7з Да нормально, слово общеупотребимое :)

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

    Спасибо за такое видео, я сколько видео посмотрел по useMemo и по useCallback не понял, а тут прям все понятно, и весь ролик я так кайфовал, как будто АСМР смотрю)))

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

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

  • @k0repan0ff
    @k0repan0ff 2 года назад +5

    Спасибо! Очень доходчиво и понятно все объяснено. Приятно смотреть.

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

      Я очень рада! 😍☺

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

    Спасибо за видео! Первое видео, в котором наглядно и понятно объяснили в чём разница между useMemo, useCallback и React.memo. Особенно между useMemo, useCallback.

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

    Спасибо за объяснение нюансов, ни у кого такого не слышал. Сам не сильно люблю использовать useMemo, так как сложно понять где он нужен а где нет. Но после видео теперь понял, где его можно юзать и как.

  • @theoty-js
    @theoty-js 2 года назад +16

    Клёво, что умеешь эмоции включать, так милее уроки получаются) буду изучать хуки, а то пока что знаю о таких как UseEffect и UseState, этого явно маловато ;) благодарю милая)

    • @webelart
      @webelart  2 года назад +2

      ☺️ круто! Спасибо!

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

    Просто огонь! Просто топ! Как все легко и структурно. Задолбался выковыривать инфу про эти хуки. Везде вроде и по делу и в то же время непонятно, что, когда и где пользовать. Спасибо!

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

    Обалденный контент. Спасибо! Жаль раньше вас не нашел

  • @ПожилойФронтендер

    Спасибо Елена, все круто и понятно, мне понравилось, подписка! Успехов и удачи!!)

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

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

  • @Mikhail.tortik001
    @Mikhail.tortik001 2 года назад +5

    Оооооооо, тема с useMemo и React.memo это топ. А то в инэте в основном инфа по useState и useEffect) Спасибо большое, жду видос про tsconfig.json😄😄

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

      Будет следующим видео! ❤

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

    Лена, спасибо за разбор работы мемоизации! Я благодаря ему смог разобрался в реальном проекте с проблемой переключения двух компонентов в табах. У тебя такой ситуации не показано и поэтому я долго исследовал исходник либы Antd и код кастомных табов, у нас на проекте, и не мог понять, почему useMemo не работало. Я и пропсы в компоненты отключил и в useMemo обернул, но они перерисовываются при каждом переключении табов и все тут. Но они же, и спропсами, в ANT'e прекрасно мемоизировались. Т.е. отрабатывали по первому разу, а потом брались из кэша. А проблема была в том, что эти компоненты заменяли друг друга в ДОМ при каждом переключении кастомных табов, т.к. брались из пропса (но это не важно в целом). И решение здесь только одно - монтировать в ДОМ сразу оба компонента (при этом они инициализируются тоже оба), а потом переключать их табами через смену стилей: display: none/block. И тогда они рендерятся заново только при реальной смене их собственных пропсов. Твой же компонент FactorialCalculation один раз монтируется в шаблоне и по нажатию на кнопку не удаляется, и поэтому useMemo для него работает. Но результат для меня очень радостный по итогу :))

  • @DevAccount-rq4ni
    @DevAccount-rq4ni Год назад

    Супер классное понятное объяснение!! Елена спасибо огромное, крутая подача, продолжайте в том же духе 🔥

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

    Огромное спасибо! Я сидел с этими темами 4 часа.

  • @bczya1
    @bczya1 9 месяцев назад

    Спасибо рекомендациям за ваш канал)

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

    Подача, как всегда - волшебно! :)))

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

    Круто, смотрю третье видео перед подготовкой к собесам.
    Спасибо )

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

    Спасибо большое за видео, очень нравится ваша подача и позитивное настроение
    Желаю побольше просмотров и развития каналу, вы классная :)

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

    Очень доходчиво объяснила 🔥
    Елена, огромная тебе благодарность 🤟🏻

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

    Елена, спасибо огромное! Лучшие видео-лекции про веб ❤

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

      ❤❤❤ Я рада, что материал полезен!

  • @mike-aaa
    @mike-aaa 10 месяцев назад

    А вот если я у родителя обернул onClick в usecallback
    И передал в дочернюю кнопку (как единсвенный параметр), которая обычная безе memo
    Она все равно перерендерится? Т.е зачем делать usecallback??? если я не делаю memo??

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

    Спасибо большое, наконец то я понял эти два хука

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

    Какая же ты крутая, Лена!

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

    Умничка! Спасибо за видео❤

  • @ЕвгенийНагаев-п9ч
    @ЕвгенийНагаев-п9ч 2 года назад

    Учу реакт, но ещё не дошёл до этих хуков, изучаю useState, useEffect, use Context. Не смотря на это Лена рассказала очень понятно про useMemo, useCallback и reactMemo. Спасибо за ценную информацию)

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

    Спасибо за разъяснение, помогло!

  • @vladimirglazkov7960
    @vladimirglazkov7960 2 года назад +7

    Елена все краше и краше с каждым видео😊

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

      😍 Спасибо!

  • @RamaRama-qv3jo
    @RamaRama-qv3jo Год назад

    Спасибо, очень доступно для понимания !

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

    Спасибо большое!!! Супер!

  • @karoche-tv
    @karoche-tv 2 года назад

    Здрасте, у меня не работает memo в реактнатив. Короче есть Parent.js
    внутри есть передающее это состояние в дочерний
    function SearcResult (){
    const typeState= useState (null);
    const root = useRoute()
    const {from, destination} = props.params
    //props.params приходит из useRoute.
    return (
    )
    }
    function UberTypes({typeState, }){
    //import types from './assets/types.js
    const [type,setType]= typeState
    const onClick = (){
    setType(type)
    }
    //
    return (
    )
    }
    Ну здесь я обернул React.memo( RuoteMap.js )потому что он неизменяется просто показывает картка и какую то анимацию после загрузки один раз и просп Стейт нечего не меняет. А тот UberTypes меняет тип при нажатии на на каждый UberTypesRow. Что я не правильно делаю? Но

  • @top-mma-news
    @top-mma-news 2 года назад

    Интересно было послушать, благодарчик

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

    Спасибо большое Елена, вчера из-за этой оптимизации провалил свой первый собес, а нужно было всего лишь раньше посмотреть ваш ролик и ответить правильно на собеседовании :(

  • @MrCortc
    @MrCortc 2 года назад +4

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

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

    Что по RoadMap?

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

      Ещё не сделала 😔 Поможете сгруппировать видео?

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

      @@webelart да конечно, помогу

  • @dm.hol.3624
    @dm.hol.3624 Месяц назад

    Мидл+ контент, то что надо. А то я вызубрил что-то про хуки, а как использовать - не понимаю. Спасибо.

  • @ИгорьГреков-я6в
    @ИгорьГреков-я6в 2 года назад

    спасибо за урок и хорошее настроение)

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

      Пожалуйста! 🥰❤ Рада, что урок понравился!

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

    да. недавно как раз именно эта инфа появилась на канале в тг React, буквально несколько дней)

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

    лайк, репост, комментарий для продвижения в топ!

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

    Привет, а не подскажешь как правильно именовать css модули при импорте их в jsx:
    import вЭтомМестеКакПравильноИменовать from './КакойТоМодуль.module.css';

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

      Да, это для nextjs

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

      @@webelart нет это для react, фронтенд часть

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

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

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

      @@Kleo_WyattПривет, да уже не актуален, но всё равно спасибо большое за потраченное время на меня, успехов вам

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

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

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

      Спасибо за комментарий! Я стараюсь, стараюсь ребята! 😘❤️

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

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

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

    Классно развиваетесь

  • @Gfifful
    @Gfifful 3 дня назад

    Спасибо

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

    Елена, а Вы просто Software Engineer или Mistress Software Engineer? 🙂 (Senior)

  • @karoche-tv
    @karoche-tv 2 года назад

    Про useReducer, useContext тоже будут?

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

      Сделаю 👍

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

    useMemo - я использовал когда создавал свой кастомный хук связанный с пагинацией (usePagination) т.к. там велись расчёты и возвращались 4 разные значения

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

    Спасибо за видео, все круто и информативно! Единственное, в некоторых местах советуют не класть компоненты в служебную папку pages в Next.js)

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

      Вроде туда только стили положила. Вообще да, это же папка для роутинга

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

      @@ReAgent003Эх, пока в Лондоне. Но Яндексу сердечки! ❤

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

    Если не хотите перерендеривать компонент не имеющих пропсов вообще (или же они не меняются по ходу программы) - вместо memo лучше вытащить в константу:
    function FHome() {}
    export const FhomeComponent = ;
    И соответственно везде использовать {FhomeComponent} вместо .
    useCallback и useMemo можно зачастую тоже избегать, просто вытаскивая объявление функции в родительский компонент. Например, есть Child, который часто перерендеривается:
    function Child(props) {
    const time = useInterval(100); //типо кастомный хук, из-за которого этот комопент будет перендериваться каждые 100мс.
    const heavyResult = useCallback(() => heavyCalc(props.foo), [props.foo]);
    }
    Вместо useCallback можно разбить его на два компонента:
    function Parent(props) {
    const heavyResult = heavyCalc(props.foo);
    return
    }

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

      Почему вы решили, что такой компонент не будет перерендериваться?

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

      @@webelart
      Это достаточно легко проверить! В вашем примере вы использовали Home = memo(Fhome). Соответственно, если где-то использовать , он перерендериваться не будет, ведь будет возвращена мемоизированная версия.
      Однако это можно заменить на следующую конструкцию: создать глобальную константу
      export const HomeComp = ;
      Если где-то использовать {HomeComp}? то он точно так же не будет перерендериваться.
      Почему? Потому что конструкция '' была вызвана только один раз, при объявлении глобально переменной.

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

      @@angelicoctahedron3646 Так вы проверяли? Почему спрашиваю, потому что перерендеринг будет.

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

      @@angelicoctahedron3646 Все компоненты, которые вы задействуете внутри, если они не мемоизированы, будут перерендерены и не важно как вы их импортируете, вынесете или не вынесете.

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

      @@webelart
      вот простой пример. redraw вызывается только один раз, при маунте компонента. И не вызывается при обновлении родителя.
      import React from 'react';
      function Child() {
      console.log('redraw');
      return Hello
      }
      const globalChild = ;
      export function App(props) {
      const [count,setCount] = React.useState(0);
      return (

      {count}
      setCount(count +1)}>
      {globalChild}

      );
      }
      Как видите, компонент не пришлось оборачивать его в memo. memo будет полезно когда у компонента меняются пропсы - но для propless компонентов (либо компонентов, чьи пропсы не меняются в ходе программы) его использование не имеет смысла.
      А магии здесь нет. Конструкция `` транслируется бабелом в createElement(Child). То есть получается, что эта функция будет вызываться каждый раз когда компонент рендерится. Но мы можем этого избежать: если будем передавать компонент через пропы (обычно через children), глобальные переменные, или используя memo.

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

    после слов будем использовать хуки useMemo, useCallback и REACT.MEMO...... REACT.MEMO Карл, реакт мемо - это хук , Карл... захотелось выключить) надеюсь оговорка, щас посмотрим дальше

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

    👍👍👍

  • @ЭльнараГайнанова-ф3к

    Жалко, что нельзя поставить млн лайков ❤

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

      Спасибо большое!!! ❤❤❤ Рада, что контент нравится! 🥰

  • @carltonloth2269
    @carltonloth2269 4 дня назад

    Хорошее видео

    • @webelart
      @webelart  4 дня назад

      Спасибо!

    • @carltonloth2269
      @carltonloth2269 3 дня назад

      @@webelart Вам огромное спасибо, очень информативное и полезное видео, как раз полностью раскрывается useMemo, useCallback

  • @АлександрКасатов
    @АлександрКасатов 2 года назад +5

    function sleep(ms) {
    const timeNow = Date.now();
    while (timeNow + ms >= Date.now());
    }
    Такая штука позволяет более наглядно имитировать тяжелые вычисления.

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

      Крутой пример!

    • @benchik100
      @benchik100 8 месяцев назад

      thanks

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

    Хороший урок! Очень позитивно и полезно, про злободневные штуки при React разработке.

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

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

  • @nth-prog8562
    @nth-prog8562 Год назад

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

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

      Что может быть лучше? Ну вот миллион долларов, например, лучше.

  • @tutnichegonet
    @tutnichegonet 2 года назад +2

    можешь по простому объяснить что такое pure component? а то ты много раз его в видео упоминаешь)

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

      Да, я под Pure компонентой имела ввиду компоненту обёрнутую в React.memo.

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

    Я может глупость спрошу, но почему бы не использовать эти хуки для запросов на сервер (fetch, или axios) ? Для некоторых данных не обязательно каждую секунду отправлять запрос на сервер, узнавать как там дела, не изменилось ли что-нибудь. Я к тому, что отправил запрос в бекэнд, получил данные, записал в стейт, и уже с этим стейтом работаешь, не перевызывая запросы на сервер (не говоря уже о том, что от сервера нужно ещё дождаться этих данных). Чем -не ресурсоёмкое- занимающее время выполнение? Почему для этих нужд не используется _useMemo_ ?

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

      Отличный вопрос! ❤️ Для этих нужд используется useEffect с пустыми скобками.

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

    Проходил тестовое и была задачка оптимизировать ререндер в 3 компоненте чтоб при вводе в инпут не происходил ререндер, нужно было обернуть ончейнж в 1 компоненте юзколлбеком и 1 компонент обернуть реакт мемо хоком

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

      Спасибо что поделились! Но вы в будущем пишите нормально называя, раза три пришлось перечитать, чтобы понять ❤️

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

      @@webelart ок спасибо, Елена снимите пожалуйста видео про стадии рендера компонентов в реакт, почему например юзеффект в чилдрене отработет перед таким же в родителе, на собесах на мидла такое спрашивали. И если в див родителя передать коллбек с рефом и консоль логом почему оно срабатывает до рендера чилдрена. Спасибо и развития вам и вашему каналу !

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

    💥💥💥

  • @ГусяНоздреватая
    @ГусяНоздреватая 2 года назад

    Учусь в уральском вузе и мечтаю уехать в Лондон, чтобы стать таким же весёлым и жизнерадостным, как Елена)

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

      Желаю, чтобы всё у вас получилось! ❤

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

      Главное учитесь, вкладывайтесь, идите к мечте и желанию, и оно точно исполнится!

  • @angular-developer-e1t
    @angular-developer-e1t Месяц назад

    Сразу видно что чувствуешь архитектуру. Не чисто на зубрёжке.

  • @АртурЦебаев
    @АртурЦебаев 2 года назад

    memo же можно также, как и хуки имортить и писать без React

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

    UseDefferedValue and UseTransition hooks please 🙏

  • @АлександрВидин-с6я
    @АлександрВидин-с6я 3 месяца назад

    Не думаю, что использовать хуки по ощущения правильно. Но спасибо за объяснения

  • @ИгорьАгаларов
    @ИгорьАгаларов 2 года назад

    Пришёл посмотреть МЕМЫ, в итоге изучил хуки)

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

    Как мне не хватало девочек тьюторов! : *****

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

    4:07 - хуки useMemo и useReact..... боже.... я понимаю что все могут оговориться, но это не значит что надо оставлять такой материал... новички посмотрят и реально будут искать хук useReact... ну проверяйте свой контент перед тем как выкладывать, это не дело

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

      Вы чего так тригеритесь, ну оговорилась, а у вас словно Солнце на Землю упало. Нормально всё. Расслабьтесь и наслаждайтесь контентом. 😘

    • @Anonym-li8eb
      @Anonym-li8eb 9 месяцев назад

      Душнила

  • @eleukhin
    @eleukhin 11 месяцев назад

    А не проще так экспортировать: export default React.memo(SomeComponent); без дополнительных именований

    • @webelart
      @webelart  11 месяцев назад

      Не имеет значения. Зависит от того как у вас линтер в команде настроен.

  • @404russ
    @404russ 2 года назад

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

    • @webelart
      @webelart  2 года назад +2

      Ахахаха, 😂 Я тут уже писала, не пугайте мою маму. Она меня смотрит.
      P.S. Мамуль наркотой не страдаю!! ЧЕСТНОЕ СЛОВО!! Люблю тебя ❤

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

      Максимум, что я пью, курю, дую! Это программирование. 💃 Так что дорогие мои подписчики, давайте вместе под ПРОГРАММИРОВАНИЕ! 😎 ААХАХ или ЗА программирование. 🤭❤‍🔥

  • @Koal-e1d
    @Koal-e1d Год назад

    Спасибо за информацию
    Но режет слух слово проПСЫ
    Что ещё за псы)
    Хотя судя по наличию видео урока про галерею с волками, видимо человек как раз любит псов)
    А я говорю прОпсы

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

      Хаха, не я не очень люблю собак. Я кошатница.

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

    накуренная ?😀😀😀😀 класс видео

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

      😂 Я не курю...

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

    Было бы здорово услышать о том как правильно делать http запросы useffect!

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

    у сайта loveholidays огромные проблемы с версткой)

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

      Конкретику дадите?

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

      @@webelart на мобильном есть небольшой scroll-x

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

      @@alexeyfilippov42 Скажите какая страница и какое у вас разрешение экрана? Пофиксим!

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

    В начале думал Она бухая.Но поняв что я без работы , и травмы. Понел что я никто

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

      😂😂 Я вообще не пью! Мой эмоциональный импакт этого не требует вообще...😁 Да и настроение разное. Ещё иногда хочется в видео, чтобы барьеры над сложностью материала снимались. Было интересно, весело и дружелюбно. ❤

    • @webelart
      @webelart  2 года назад +2

      Кстати и да, ещё хотела написать! Вы тут поаккуратнее с такими комментариями, меня мама смотрит! 😎 В прошлый раз мне пришлось убеждать, что я не под наркотой тут в Лондоне, без присмотра😅😅

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

      @@webelart Незнаю как ответит на этот вопрос Ты ведь взрослая а Мой коммент Жизнейщая жизабенейшая своя логика и своя правда

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

      ​@@hasegawataizou5038 Я просто решила пошутить, всё нормально 😂😂 Пишите разные комменты! Я серьёзно, как чувствуете! Это очень КРУТО!
      А маме я просто передаю привет. Мамуль, если ты это читаешь, люблю тебя безмерно, со мной всё хорошо ❤🙃

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

      @@webelart а я уже начел думать что со мной что то не так

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

    Слишком симпотная.

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

      😍💃Спасибо!! Очень приятно!!!

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

      @@webelart Просто правда.

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

    Ну слабенько как-то про то, где надо, а где нет. Делать по ощущениям, это не совет. Только ради этого по сути и смотрел, а тут ничего нового.

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

      Да, ладно вам, не расстраивайтесь! :) Но в тоже время я понимаю вас, мне кажется было бы здорово как-то через профилирование пройти и чтобы конкретные кейсы были и исследование, тогда это было бы огонь. Мне здесь ещё подрасти тоже надо и опыта набраться. Как только нахватаюсь кейсов побольше, уверена сниму ещё видео. ❤

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

      Кстати если вдруг увидите видео с хорошим объяснением профилирования и сравнения с мемоизацией, тоже кидайте!

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

    Рекурсия - тяжелая функция🤡🤡 завязывай

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

      Давай ты уж сам себе шнурки как-нить завяжешь 😉

  • @Antonym-b5o
    @Antonym-b5o Год назад +1

    если честно, проще доку почитать, ничего не понятно

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

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

    • @maximkalenkovich
      @maximkalenkovich 6 месяцев назад

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

  • @cybersystem5137
    @cybersystem5137 7 месяцев назад +1

    КомпоненТ. Не ТА, Т! Зачем коверкать?

  • @cybersystem5137
    @cybersystem5137 7 месяцев назад

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

    • @enjoymtx
      @enjoymtx 5 месяцев назад

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

    • @cybersystem5137
      @cybersystem5137 5 месяцев назад

      @@enjoymtx ты главное побольше запасись ими, я еще за третьим приду и четвертым

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

    Привет, когда стрим ?

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

      Уже был на канале Алгосиков с Виктором ruclips.net/video/SJeQgSdy6Sk/видео.html. Хотите ещё? :)))

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

      @@webelart Ну это вам тогда опрос надо устроить на стёт проведения нового стрима). Я это всенда за) всякий движ)

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

      @@evgeniy3370 Сделаю!

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

      В telegram! ❤