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

[js] Wyświetlanie danych z tablicy lub pustego pola

VPS Starter Arubacloud
0 głosów
415 wizyt
pytanie zadane 8 lutego 2019 w JavaScript przez niezalogowany

Chce za pomocą jednego funkcji wyświetlającej formularz móc dodawać i edytować dane. W przypadku edycji funkcja dostanie aktualne dane i ma je wpisać jako wartość. Jeżeli funkcja nie dostaje danych druga linijka zwraca błąd. To jest poprawny zapis? Czemu dopiero druga linia zwraca błąd?

`<input value = '${dane["imie"] || ""}'>
<input value = '${dane["zamieszkanie"]["miasto"] || ""}'>`

 

komentarz 8 lutego 2019 przez xmentor Nałogowiec (49,520 p.)
Ciężko mi zrozumieć Twój opis. Możesz opisać bardziej szczegółowo(np. w liście kroków co ma się dziać i kiedy) + dać kod?
komentarz 8 lutego 2019 przez niezalogowany
edycja 8 lutego 2019
 $(document).on("click", "#zapisz_uczniowie_form", dodaj_ucznia_function);
 $(document).on("click", "#edytuj_uczniowie_button", edytuj_ucznia_function);

function uczniowie_form_function(edytuj_array) {
html = `  <div class = 'form_element'><label>Imie *: <input value = '${edytuj_array["imie"] || ""}' data-type = 'imie/nazwisko' type = 'text' id = 'imie_uczniowie_form' autofocus required></label></div>
  <div class = 'form_element'><label>Drugie imie: <input value = '${edytuj_array["drugie_imie"] || ""}' data-type = 'imie/nazwisko' type = 'text' id = 'drugie_imie_uczniowie_form'></label></div>
  <div class = 'form_element'><label>Nazwisko *: <input value = '${edytuj_array["nazwisko"] || ""}' data-type = 'imie/nazwisko' type = 'text' id = 'nazwisko_uczniowie_form' required></label></div>
  <fieldset><legend>Zameldowanie</legend>
  <div class = 'form_element'><label>Miasto *: <input value = '${edytuj_array["zameldowanie"]["miasto"] || ""}' data-type = 'miejsce' required type = 'text' id = 'miasto_zameldowania_uczniowie_form'></label></div>
  <div class = 'form_element'><label>Ulica *: <input value = '${edytuj_array["zameldowanie"]["ulica"] || ""}' data-type = 'ulica' required type = 'text' id = 'ulica_zameldowania_uczniowie_form'></label></div>
  <div class = 'form_element'><label>Kod pocztowy *: <input value = '${edytuj_array["zameldowanie"]["kod"] || ""}' data-type = 'kod_pocztowy' required type = 'text' id = 'kod_pocztowy_zameldowania_uczniowie_form' placeholder = 'xx-xxx' ></label></div></fieldset>`
  <div class = 'form_element><button id = "zapisz_uczen_button">Zapisz</button> 
$("#zawartosc").html(html);
}

function edytuj_uczen_form_function() {
  console.log("edytuj_uczen_form_function");
  id = $(this).attr("id");
  for(i = 0; i < uczniowie.length; i++)
    if(uczniowie[i]["id"] == id){
      uczniowie_form_function(uczniowie[i]); //uczniowie to tablica zawierająca dane 
      break;
    }
}

Nie chce robić dwóch funkcji do edycji i dodawaniu jeżeli jest to ten sam formularz. W momencie dodawania kiedy funkcja uczniowie_form_function() nie dostaje tablicy z danymi dostaje błąd o o niezdefiniowanych danych.

komentarz 8 lutego 2019 przez xmentor Nałogowiec (49,520 p.)
Zrób sobie funkcje pomocniczą, która będzie sprawdzać czy zadany jej obiekt 'istnieje', ma jakąś wartość, jeżeli tak to zwracasz wartość, którą przekazałeś do tej funkcji, w innym wypadku wyrzucasz pustego stringa.
komentarz 8 lutego 2019 przez niezalogowany
edycja 8 lutego 2019
Bardziej zastanawia mnie czemu działa dla edytuj_array["imie"] a nie działa dla edytuj_array["zamieszkanie"]["miasto"]?
komentarz 9 lutego 2019 przez ScriptyChris Mędrzec (190,190 p.)

A co masz w polu edytuj_array["zamieszkanie"]? Może nie ma tam pola miasto w momencie, gdy chcesz je pobrać?

komentarz 9 lutego 2019 przez niezalogowany
edytuj_array["zamieszkanie"] ma 3 tablice miasto, ulica, kod. W momencie dodawania osoby nie ma tablicy zamieszkanie ale też nie ma wartości imię a nie zwraca błędu.
komentarz 9 lutego 2019 przez xmentor Nałogowiec (49,520 p.)
Dobrym pomysłem będzie tworzenie osoby w raz z defaultowymi wartościami, czyli pustymi stringami, nie byłoby wtedy problemu :)

Coś w stylu: https://codepen.io/kkondratowicz/pen/xMYero?editors=0012
komentarz 9 lutego 2019 przez niezalogowany
Tak wtedy działa

Zaloguj lub zarejestruj się, aby odpowiedzieć na to pytanie.

Podobne pytania

0 głosów
3 odpowiedzi 2,212 wizyt
0 głosów
1 odpowiedź 127 wizyt
pytanie zadane 14 grudnia 2022 w JavaScript przez TOWaD Mądrala (5,700 p.)
+1 głos
0 odpowiedzi 288 wizyt
pytanie zadane 29 kwietnia 2021 w JavaScript przez TOWaD Mądrala (5,700 p.)

92,451 zapytań

141,261 odpowiedzi

319,073 komentarzy

61,853 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

Akademia Sekuraka 2024 zapewnia dostęp do minimum 15 szkoleń online z bezpieczeństwa IT oraz dostęp także do materiałów z edycji Sekurak Academy z roku 2023!

Przy zakupie możecie skorzystać z kodu: pasja-akademia - użyjcie go w koszyku, a uzyskacie rabat -30% na bilety w wersji "Standard"! Więcej informacji na temat akademii 2024 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!

...