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

QuerySelectorAll i pusty NodeList

Object Storage Arubacloud
0 głosów
157 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 (344,860 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 (344,860 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ź 190 wizyt
pytanie zadane 12 lutego 2018 w JavaScript przez Kamil M Bywalec (2,340 p.)
+1 głos
2 odpowiedzi 152 wizyt
pytanie zadane 5 stycznia 2022 w JavaScript przez Jacek Śmiel Użytkownik (510 p.)
+1 głos
3 odpowiedzi 479 wizyt
pytanie zadane 2 lipca 2017 w JavaScript przez lapacz.kornel Mądrala (6,930 p.)

92,584 zapytań

141,433 odpowiedzi

319,668 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!

...