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

Teoretycznie prosty problem w React

Object Storage Arubacloud
0 głosów
130 wizyt
pytanie zadane 12 sierpnia 2019 w JavaScript przez Piotrek Jeżewski Nowicjusz (120 p.)

Próbuje przekazać liste ze state do wyrenderowania jej w ul.
Niestety przechodzi tylko h1 ktora pelnila tu role tylko poglądową, czy cokolwiek działa.

Prosiłbym o jakieś nakierowanie, dopiero się ucze i obawiam się, że strasznie to przekombinowałem...

Link z kodem:

https://pastebin.com/tysyhmjS

 

2 odpowiedzi

+2 głosów
odpowiedź 12 sierpnia 2019 przez Milesq Nałogowiec (32,020 p.)

1) w state trzymasz obiekt który ma jeden klucz "list" a pod nim kryje się wartość "sok".

state = {
    list: "kebab",
    list: "cola",
    list: "sok"
  }

Jeśli chcesz zrobić tablicę zrób tak:

state = {
    list: ["kebab", "sok", "cola"]
  }

teraz w state.list kryje się tablica z tymi trzema rzeczami.

2) 

<ul><listItems name={this.state.list} /></ul>
const listItems = (props) => {
  return (
    <li>{props.name}</li>
  )
}

listItems zawsze zwróci tylko jeden element i będzie to jeden tag li. Jeśli chcesz wyświetlić je wszystkie zrób tak:

const listItems = (props) => {
  return (
    <>
       {props.list.map(item => (<li>{item}</li>))}
    </>
  )
}

i wtedy jako propsa do tego komponentu przekazujesz list a nie name. Jeśli chodzi o 

<></>

to to są fragmenty, możesz zwrócić więcej niż jeden root element bez opakowywania tego w span'y czy div'y

komentarz 12 sierpnia 2019 przez UltraSF Stary wyjadacz (11,740 p.)
komentarz 12 sierpnia 2019 przez UltraSF Stary wyjadacz (11,740 p.)
na playground wgl nie szło, ale może to rzeczywiście efekt środowiska :P
1
komentarz 12 sierpnia 2019 przez Piotrek Jeżewski Nowicjusz (120 p.)
Dziękuje CI bardzo za szczegółowe wyjaśnienie problemu.
Niestety porobiłem mnóstwo błedów podstawowych.
Dałem plusika i bardzo się ciezze, że zrobiłeś to z użyciem metody map() bo sam probowałem ale miałem problem z odpowiednią składnią.
komentarz 12 sierpnia 2019 przez Piotrek Jeżewski Nowicjusz (120 p.)
Faktycznie musiałem jeszce zmienić w tym przypadku odwołanie z name na list.
ale jak zacząłem analizować to co napisał Milesq to od razu to wychwyciłem :)
+1 głos
odpowiedź 12 sierpnia 2019 przez UltraSF Stary wyjadacz (11,740 p.)

Po pierwsze ten obiekt nie ma sensu. Obiekty mają unikatowe kluczę... to raczej powinno być
 

{
    list: [
        "kebab",
        "cola",
        "sok"
    ]
}


Ogólnie jak zmienisz nazwę na ListItem (usunąłem też s bo to jest pojedynczy item) to zadziała. Chodziło o dużą literę na początku.
Jednak w react mamy hooki i ja bym szedł w tym kierunku:
 

const ListItem = props => {
  console.log(props);
  return <li>{props.name}</li>;
}
const ShoppingList = () => {
  const [list, setList] = useState(["kebab", "cola", "sok"]);

  return (
     <>
        <h1>Lista zakupów</h1>
        <ul>
            {list.map(item => <ListItem name={item} />)}  
        </ul>
      </>
  );
}

ReactDOM.render(<ShoppingList />, mountNode)

Kod napisany na kolanie, ale działa i chyba jest poprawniejszy :P

 

1
komentarz 12 sierpnia 2019 przez Piotrek Jeżewski Nowicjusz (120 p.)
Dzięki wielkie za odpowiedź i nakierowanie mnie gdzie mam jeszcze spore braki.
Więcej czasu zajeło mi sprawdzenie i zrozumienie tego co chciałeś przekazać niż zapewne Tobie samo pisanie.
Muszę jeszcze się poduczyć a propo tego co można stosować aby pisać schludniejszy i krótszy kod w React.
Oczywisćie plusik poszedl :)

Podobne pytania

+1 głos
1 odpowiedź 1,996 wizyt
pytanie zadane 7 lutego 2017 w JavaScript przez Alwox Gaduła (4,840 p.)
0 głosów
1 odpowiedź 124 wizyt
pytanie zadane 31 grudnia 2019 w JavaScript przez `Krzychuu Stary wyjadacz (13,940 p.)
+1 głos
0 odpowiedzi 115 wizyt

92,580 zapytań

141,433 odpowiedzi

319,665 komentarzy

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

...