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

Dostanie sie do atrybutów

Object Storage Arubacloud
+1 głos
313 wizyt
pytanie zadane 24 listopada 2021 w JavaScript przez Olivier Mazur Użytkownik (680 p.)
Witam mam taki kod:
for (var i = 0; i < self.placeholders.length; i++) {
      $placeholder = self.placeholders[i].$item;
      console.log($placeholder)
}

console wyswietla mi cos takiego:

Jak się dostać teraz do tych wszystkich divow? Bo chcialbym powyciagac z nich atrybuty za pomocą dataset

1
komentarz 24 listopada 2021 przez ScriptyChris Mędrzec (190,190 p.)

Czym jest zmienna self? To jakaś referencja do window / this? Co się pokazuje, gdy w pętli wylogujesz $placeholder.length?

komentarz 24 listopada 2021 przez Olivier Mazur Użytkownik (680 p.)

self odnosi się do obiektu to cos takiego jak this w klasach. Jest to bardzo stary kod i cięzko mi go zrozumiec do konca. Po wykonsolowaniu mam cos takiego:

1 odpowiedź

+5 głosów
odpowiedź 24 listopada 2021 przez ScriptyChris Mędrzec (190,190 p.)
wybrane 24 listopada 2021 przez Olivier Mazur
 
Najlepsza

Sądząc po długości listy, która wynosi 1, to do jedynego elementu możesz się dostać po prostu podając indeks 0:

console.log('$placeholder item:', $placeholder[0])

Jeśli chciałbyś sobie te elementy wyciągnąć do tablicy poza jQuery, to np. w ten sposób:

const elements = [...self.placeholders].map(element => element.$item[0]);

 

1
komentarz 26 listopada 2021 przez ScriptyChris Mędrzec (190,190 p.)

Użycie $( .. ) pozwala m.in owinąć zwykłą kolekcję elementów w jQuery-owy odpowiednik, dzięki czemu można na tym używać metod z jQuery. Biblioteka posługuje się swoim "typem" dla elementów w DOM, więc jeśli operujesz na natywnym elemencie/kolekcji DOM, to najpierw musisz owinąć to w kolekcję/typ jQuery, żeby móc na tym dalej działać poprzez API biblioteki; chociaż nie wnikałem, czy są jakieś hacki, aby używać metod jQuery bez owijania danych wejściowych (a'la Function.prototype.call).

komentarz 26 listopada 2021 przez Olivier Mazur Użytkownik (680 p.)
dziękuję jeszcze raz
komentarz 26 listopada 2021 przez ScriptyChris Mędrzec (190,190 p.)

P.S. Wg mnie warto jest stosować konwencję prefixowania nazw zmiennych znakiem dolara, żeby móc na pierwszy rzut oka odróżnić zmienną o wspomnianym typie jQuery od natywnego elementu/kolekcji z DOM. Więc nazwałbym anchor ⇒ $anchor oraz self.placeholders ⇒ self.$placeholders (jeśli faktycznie to jest kolekcja elementów jQuery, a nie natywnych DOM).

komentarz 26 listopada 2021 przez Olivier Mazur Użytkownik (680 p.)

Jeszcze mam takie pytanie, zrobilem:

console.log($(self.placeholders))
 console.log(self.placeholders)

https://zapodaj.net/92c9c4d282855.png.html

Rozumiem, ze init to nazwa kolekcji jquery, a ten drugi console to zwykla tablica?

1
komentarz 26 listopada 2021 przez ScriptyChris Mędrzec (190,190 p.)
Na to wygląda, sądząc po prototypach obu.

Podobne pytania

0 głosów
4 odpowiedzi 549 wizyt
pytanie zadane 16 lutego 2019 w Rozwój zawodowy, nauka, praca przez klaudiusz20046 Nowicjusz (160 p.)
0 głosów
3 odpowiedzi 837 wizyt
pytanie zadane 17 czerwca 2021 w Rozwój zawodowy, nauka, praca przez Olafisz Nowicjusz (230 p.)
0 głosów
1 odpowiedź 129 wizyt
pytanie zadane 4 marca 2017 w Urządzenia mobilne przez Maciej Kaniewski Nowicjusz (120 p.)

92,572 zapytań

141,422 odpowiedzi

319,644 komentarzy

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

...