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

Animacja wielu elementów

Object Storage Arubacloud
0 głosów
152 wizyt
pytanie zadane 6 lipca 2019 w JavaScript przez matrimex Użytkownik (810 p.)

Cześć,

mam taki problem, że potrzebowałem animacji do liczb , no to uznałem, że wezmę gotowca i tak zrobiłem, wziąłem:

https://github.com/bfintal/Counter-Up2 , podpiąłem i wszystko śmiga, problem jest, że autor podaje:

import counterUp from 'counterup2'

const el = document.querySelector( '.counter' )

counterUp( el, {
    duration: 1000,
    delay: 16,
} )

Czyli pobiera mi tylko jeden element .counter a ja mam ich kilka i chcę, żeby animowały się wszystkie, stwierdziłem, że z el zrobię querySelectorAll , albo jako tablicę, ale tu jest mój problem, że w jego kodzie (tak mi się wydaje) elementy są jako liczba pojedyncza i nie mogę tak, a przynajmniej wyskakuje mi taki błąd w konsoli:

counter.js:57 Uncaught TypeError: Cannot set property 'visibility' of undefined
    at stopCountUp (counter.js:57)
    at counterUp (counter.js:15)
    at my-counter.js:5

Tutaj jest plik counter.js: https://github.com/bfintal/Counter-Up2/blob/master/index.js

* my-counter.js to jest ten kod co u góry wkleiłem

 

Idzie to jakoś rozwiązać czy tylko ten kod będzie działał do jednego elementu i jak chcę do wszystkich to powinienem wziąć jakiś inny? (jak tak to jaki?)

 

Pozdrawiam

2 odpowiedzi

0 głosów
odpowiedź 6 lipca 2019 przez Chess Szeryf (76,710 p.)
edycja 6 lipca 2019 przez Chess
<body style="background: darkgoldenrod;">

<div id="div1">hello</div>
<div id="div2">hello2</div>
const x = (el, options = {}) => {
  console.log(this);
  console.log(el);
  console.log(options);

  el.style.background = options.color;
}

//x.bind(null, document.getElementById('div1'), {"color" : "orange"})();

const elements = [document.getElementById('div1'), document.getElementById('div2')];
const colors = ['orange', 'green'];

let length_e;

if(elements.length === colors.length) {
  length_e = elements.length;
} else {
  length_e = 0;
}

for(let i=0;i<length_e;i++) {
  x(elements[i], {"color" : colors[i]});
}
</body>

Paczka (kod - "framework") nie pozwala chyba na prototypowanie i/lub bindowanie, więc pozostaje chyba tylko napisać pętlę.

0 głosów
odpowiedź 6 lipca 2019 przez thryndl Nałogowiec (30,470 p.)

Możesz przeleć forEachem przez nodeListe z querySelectorAll i zapiąć counterUp na pojedynczy element.

const elems = document.querySelectorAll(".counter");

elems.forEach(el => {
  counterUp(el, {
    duration: 1000,
    delay: 16
  });
});
    <div class="counter">1,123,456 downloads</div>
    <div class="counter">78,937 users</div>
    <div class="counter">3,111,738 posts</div>

 

Podobne pytania

0 głosów
3 odpowiedzi 872 wizyt
pytanie zadane 26 grudnia 2018 w HTML i CSS przez AQ1234 Nowicjusz (160 p.)
0 głosów
2 odpowiedzi 356 wizyt
pytanie zadane 12 listopada 2022 w JavaScript przez xTMx3 Obywatel (1,560 p.)
0 głosów
1 odpowiedź 198 wizyt
pytanie zadane 2 listopada 2017 w JavaScript przez ziemjok Gaduła (4,160 p.)

92,555 zapytań

141,404 odpowiedzi

319,560 komentarzy

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

...