Задать вопрос
@soul7

В Next-JS хук UseEffect() запускается дважды. Я поставил вторым аргументом пустой массив, не помогло. Как это исправить?

В Next-JS хук UseEffect() запускается дважды. Я слышал, что нужно указать пустой массив в качестве второго аргумента, чтобы исправить это в React.
В моем случае в Next-JS это не работает. (Насколько я знаю, Next-JS основан на React).

Я нашел один способ: в next.config.js установить reactStrictMode: false. И это работает, UserEffect вызывается один раз.

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

_app.js:
import '../styles/globals.css';
import React, { useEffect, useState, useRef } from 'react';

function MyApp({ Component, pageProps }) {
  if (typeof window !== "undefined") {

    useEffect(() => {
      console.log('Component Did Mount') //вызывается дважды :с
    }, [])


  return <Component {...pageProps} />
}


export default MyApp
  • Вопрос задан
  • 953 просмотра
Подписаться 1 Простой Комментировать
Решения вопроса 1
@wonderingpeanut
Стрикт мод рендерит каждый компонент дважды. Это происходит только в девелопмент моде, т.е. в продакшн билде этого не будет происходить.

Это никак не исправить, кроме как отключением стрикт мода.

В юзэфект можно добавить условие
if (notAlreadyExecuted) { ... } // do something
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

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

Похожие вопросы
Rocket Смоленск
от 80 000 до 130 000 ₽
Wanted. Москва
от 250 000 до 400 000 ₽
Wanted. Санкт-Петербург
До 220 000 ₽
27 дек. 2024, в 03:33
1500 руб./за проект
27 дек. 2024, в 02:41
50000 руб./за проект
26 дек. 2024, в 23:03
500 руб./в час