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

QuerySelectorAll i pusty NodeList

VPS Starter Arubacloud
0 głosów
182 wizyt
pytanie zadane 27 listopada 2018 w JavaScript przez Apper97 Obywatel (1,380 p.)

Cześć Generuje elementy HTML'owe za pomocą js'a. Mają one oczywiście swoje klasy po których łapie je za pomocą querySelectorAll niestety otrzymuje pusty nodelist.

 

function displayCustomers(customersModel) {
				var table = document.createElement('table');
				var tbody = document.createElement('tbody');
				var tbodyInfo = `<tr>
                    <th>Name</th>
                    <th>ID</th> 
                    <th>CustomerId</th>
                    <th>Customize</th>
                </tr>`;
				tbody.innerHTML += tbodyInfo;
        		 customersModel.customers.forEach(function(customer) {
					tbody.innerHTML +=`<tr>
                    <td class="userName">${customer.name}</td>
                    <td>${customer.loid}</td> 
                    <td>2</td>
                    <td><button class="customizeUser">+</button></td>
				</tr>`
				
				});
				table.appendChild(tbody);
				document.body.appendChild(table);
				
			}
			var customizeButtons = document.querySelectorAll(".customizeUser");
			console.log(customizeButtons);

Niestety w tym wypadku jest pusty NodeList, jakies porady? 

1 odpowiedź

0 głosów
odpowiedź 27 listopada 2018 przez adrian17 Ekspert (349,240 p.)
Na oko widzę dwie opcje:

- nie widzę, gdzie wywołujesz `displayCustomers`. Jeśli odpalasz `custom.lo` od razu po zdefiniowaniu funkcji bez wywoływania jej, to nic dziwnego.

- `customersModel.customers` jest pusty.
komentarz 27 listopada 2018 przez Apper97 Obywatel (1,380 p.)
function fetchCustomers() {
            	invokeGET("http://localhost:8000/payments/getCustomers.json", {
            		onSuccess: function(data) {
            			displayCustomers(data);
            		},
            		onError: function(data) {
            			alert("Error");
            		},
            	});            	
            }

wywolanie displayCustomers, nie chcialem po prostu calego kodu wrzucac bo to bez sensu.

Customersmodel.customers nie ejst pusty, zwraca mi wszystkich customerow z jsona

komentarz 27 listopada 2018 przez adrian17 Ekspert (349,240 p.)
To kolejne pytanie: czy nawet po pokazaniu listy na stronie, wpisanie `document.querySelectorAll(".customizeUser")` w konsoli pokazuje postą listę?

Osobiście zgaduję, że jest to spowodowane asynchronicznością i po prostu próbujesz wyciągnąć elementy, zanim jeszcze dostałeś odpowiedź z serwera.
komentarz 27 listopada 2018 przez Apper97 Obywatel (1,380 p.)
Pewnie jest jak mowisz, z tym, ze jak obejsc te asynchronicznosc? Dodaje elementy z klasa w funkcji-to jasne, ale jak je wyswietlic?
komentarz 27 listopada 2018 przez Apper97 Obywatel (1,380 p.)
chociaz np. getElementByClassName-działa

Podobne pytania

0 głosów
1 odpowiedź 202 wizyt
pytanie zadane 12 lutego 2018 w JavaScript przez Kamil M Bywalec (2,340 p.)
+1 głos
2 odpowiedzi 175 wizyt
pytanie zadane 5 stycznia 2022 w JavaScript przez Jacek Śmiel Użytkownik (510 p.)
+1 głos
3 odpowiedzi 633 wizyt
pytanie zadane 2 lipca 2017 w JavaScript przez lapacz.kornel Mądrala (6,930 p.)

92,977 zapytań

141,939 odpowiedzi

321,182 komentarzy

62,303 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.

Wprowadzenie do ITsec, tom 2

Można już zamawiać tom 2 książki "Wprowadzenie do bezpieczeństwa IT" - będzie to około 650 stron wiedzy o ITsec (17 rozdziałów, 14 autorów, kolorowy druk).

Planowana premiera: 30.09.2024, zaś planowana wysyłka nastąpi w drugim tygodniu października 2024.

Warto preorderować, tym bardziej, iż mamy dla Was kod: pasja (użyjcie go w koszyku), dzięki któremu uzyskamy dodatkowe 15% zniżki! Dziękujemy zaprzyjaźnionej ekipie Sekuraka za kod dla naszej Społeczności!

...