• 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

0 głosów
58 wizyt
pytanie zadane 8 lutego w JavaScript, jQuery, AJAX przez 12david12 Mądrala (6,530 p.)

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 przez xmentor Nałogowiec (48,760 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 przez 12david12 Mądrala (6,530 p.)
edycja 8 lutego przez 12david12
 $(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 przez xmentor Nałogowiec (48,760 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 przez 12david12 Mądrala (6,530 p.)
edycja 8 lutego przez 12david12
Bardziej zastanawia mnie czemu działa dla edytuj_array["imie"] a nie działa dla edytuj_array["zamieszkanie"]["miasto"]?
komentarz 9 lutego przez JSHolic Szeryf (77,300 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 przez 12david12 Mądrala (6,530 p.)
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 przez xmentor Nałogowiec (48,760 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 przez 12david12 Mądrala (6,530 p.)
Tak wtedy działa

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

Podobne pytania

0 głosów
3 odpowiedzi 668 wizyt
0 głosów
1 odpowiedź 258 wizyt
0 głosów
1 odpowiedź 64 wizyt
pytanie zadane 24 stycznia w JavaScript, jQuery, AJAX przez Bialy03 Początkujący (350 p.)
Porady nie od parady
Możesz ukryć, zamknąć lub zmodyfikować swoje pytanie, za pomocą przycisków znajdujących się pod nim. Nie krępuj się poprawić pochopnie opublikowanego pytania czy zamknąć go po uzyskaniu satysfakcjonującej odpowiedzi. Umożliwi to zachowanie porządku na forum.Przyciski pytania

60,253 zapytań

105,938 odpowiedzi

220,099 komentarzy

32,461 pasjonatów

Przeglądających: 334
Pasjonatów: 18 Gości: 316

Motyw:

Akcja Pajacyk

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

Oto dwie polecane książki warte uwagi. Pełną listę znajdziesz tutaj.

...