miliko0022
@miliko0022
Краткие личные сведения, включая интересующую вас

Нужно ли использовать useMemo в hooks?

я создал useBanner hooks

const useBanner = (array, yardage) => {
  const [bannArr, setBannArr] = useState(array.slice(0, yardage));
  const [bannListIndex, setBannIndex] = useState(1);

  return {
   ....
  };
};

Правильно ли я делаю что значение и props кидаю в useState ?
допустимо я использовать useBanner.

const Banner= ({
  array,
  yardage
}) => {
  const { bannForth, bannBeck, bannArr } = useBanner(array, yardage);
  return (
    ...
  );
};

когда здесь будут меняться props .
Будет ли меняться состояние в useBanner.
или это считается антипаттерны я должен написать всё это в useMemo

const useBanner = (array, yardage) => {
  const [bannArr, setBannArr] = useState([]);
  const [bannListIndex, setBannIndex] = useState(1);

 useMemo(() => {
    setBannArr(array.slice(0, yardage));
    setBannIndex(1);
  }, [array, yardage]);

 
  return {
   ....
  };
};
  • Вопрос задан
  • 864 просмотра
Решения вопроса 1
rockon404
@rockon404 Куратор тега React
Frontend Developer
Для дорогостоящих операций лучше использовать ленивую инициализацию состояния:
const useBanner = (array, yardage) => {
  const [bannArr, setBannArr] = useState(() => array.slice(0, yardage));
  const [bannListIndex, setBannIndex] = useState(1);

  return {
   ....
  };
};

Не думаю, что в первом хуке тут будет какой-либо выигрыш в производительности.
Во втором ленивую инициализацию делать бессмысленно.
Ответ написан
Пригласить эксперта
Ответы на вопрос 1
Robur
@Robur
Знаю больше чем это необходимо
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
21 нояб. 2024, в 19:09
5000 руб./за проект
21 нояб. 2024, в 17:47
7000 руб./за проект
21 нояб. 2024, в 17:30
1500 руб./за проект