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

question-closed Dziwna kolejność renderowania w React dla OR [React.js]

Object Storage Arubacloud
0 głosów
226 wizyt
pytanie zadane 23 lipca 2021 w JavaScript przez Oskar Szkurłat Bywalec (2,780 p.)
zamknięte 23 lipca 2021 przez Oskar Szkurłat

Cześć,
Napotkałem taki problem i nie bardzo rozumiem skąd może wynikać. Podczas załączania strony opartej o React'a mam w głównym komponencie App prostą logikę wyboru w zależności od stanu z ciasteczek. Wykonsolowałem wartość, jaka jest w obiekcie i obiekt na każdym swoim etapie dobrze widzi wartość true z cookie.
Nie rozumiem do końca dlaczego dla następującego fragmentu kodu...

import React, { useState } from "react";
import Cookies from 'js-cookie';

function App() {
  const auth = Cookies.get('X')
  const [authorized, setAuthorized] = useState(auth)
  console.log('auth', auth, authorized) //zwraca 'auth true true' każdorazowo

return (
    <div className="App">
      {authorized === false ? (
        <PanelA />
      ) : (
        <PanelB />
      )
)
}

... działa to tak, że wpierw pomimo stanu true mi renderuje, jakby to był false (zauważalne dla oka), następnie przerenderowuje się i ustawia się poprawnie do true. Co równie ciekawe, jak zamienie kolejność na:
 

 {authorized === true ? (
        <PanelB />
      ) : (
        <PanelA />
      )

jest odwrotny problem. 

Próbowałem wcześniej wczytać już cookie na poziomie index.js i propsami przekazać i wartość domyślną stanu ustawić z propsów ale jest ten sam rezultat.

Czy ma ktoś pomysł, w jaki sposób mógłbym to naprawić? :( Z góry dzięki

komentarz zamknięcia: Sam znalazłem przyczynę.

1 odpowiedź

0 głosów
odpowiedź 23 lipca 2021 przez Oskar Szkurłat Bywalec (2,780 p.)

Nvm, okazało się, że biblioteka Cookie zwracała mi string, który był wpisywany w state, a dopiero potem był traktowany jako boolean, pomogło rzutowanie z samego początku na boolean, tzn. 


  const auth = (Cookies.get('X') === 'true')

 

Podobne pytania

0 głosów
1 odpowiedź 504 wizyt
0 głosów
1 odpowiedź 250 wizyt
0 głosów
1 odpowiedź 99 wizyt
pytanie zadane 17 marca 2016 w PHP przez niezalogowany

92,576 zapytań

141,426 odpowiedzi

319,652 komentarzy

61,961 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!

...