• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

React.js Hook useEffect

Object Storage Arubacloud
+1 głos
151 wizyt
pytanie zadane 27 maja 2021 w JavaScript przez p4wix Obywatel (1,040 p.)
Cześć, mam pytanie odnośnie hooka useEffect w react. Rozumiem uruchamia się zawsze gdy zmienimy stan w wartości w której przekażemy do tablicy która jest drugim argumentem funkcji, Oraz że gdy tablica jest pusta to wykonuje się tylko raz przy pierwszym renderze. I teraz moje pytanie czy jest możliwość aby ten hook nie wykonał się przy pierwszym renderze strony tylko dopiero przy zmienię wartości elementu przekazanego do tablicy?

Z góry dzięki za odpowiedź!

1 odpowiedź

+2 głosów
odpowiedź 27 maja 2021 przez Milesq Nałogowiec (32,020 p.)

Nie ma do tego specjalnego hooka. Możesz doinstalować paczkę, która daje bardziej intuicyjne hooki. Możesz też po prostu sprawdzić, czy efekt został już raz uruchomiony i jeśli nie, to po prostu robisz return. Ja używam takiego helpera:

import { DependencyList, EffectCallback, useEffect, useRef } from 'react'

function useDidChanged(effect: EffectCallback, deps?: DependencyList) {
  const isMounted = useRef(false)

  useEffect(() => {
    if (!isMounted.current) {
      isMounted.current = true
      return
    }

    effect()
  }, deps)
}

 

komentarz 27 maja 2021 przez rafal.budzis Szeryf (85,260 p.)

Wydaje mi się że funkcja effect powinna być dodana do tablicy zależności ;) 
 

  useEffect(() => {
    if (!isMounted.current) {
      isMounted.current = true
      return
    }
    effect()
  }, [effect, ...deps])

Jednak mnie zastanawia po co robić takiego hooka? Jeszcze nigdy nie miałem potrzeby użycia takiej konstrukcji a pisze z React już 3 lata zanim jeszcze weszły hooki. Zastanawiam się czy czegoś nie robię źle :/ ?

Podobne pytania

0 głosów
1 odpowiedź 279 wizyt
pytanie zadane 19 stycznia 2022 w JavaScript przez gunaterek Bywalec (2,760 p.)
+1 głos
1 odpowiedź 308 wizyt
pytanie zadane 31 stycznia 2022 w JavaScript przez Oskar Szkurłat Bywalec (2,780 p.)
0 głosów
1 odpowiedź 283 wizyt
pytanie zadane 29 grudnia 2020 w JavaScript przez sKodowany Obywatel (1,150 p.)

92,580 zapytań

141,432 odpowiedzi

319,664 komentarzy

61,965 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...