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

Javascirpt i jquery - funkcja animate()

Object Storage Arubacloud
0 głosów
204 wizyt
pytanie zadane 27 marca 2016 w JavaScript przez VDI Początkujący (260 p.)
Witam serdecznie, mam problem z funkcją animate która dziala dla okreslonej liczby milisekund. Jednak na potrzeby programu chcialbym te liczbe przeslac z pola tekstowego do ktorego wpisujemy ilosc tych milisekund. Nie dziala mi to za pomoca var ilosc=document.getElementById("ilosc_rzutow").value ;o prosilbym o pomoc w rozwiazaniu problemu! Funkcja wyglada tak ("animacja" to klocek ktory ma sie powiekszac wszerz, "button" to przycisk ktory wywoluje funkcje, "ilosc_rzutow" to pole z ktorego pobieramy czas jak dlugo ma sie ten klocek poszerzac):

$(document).ready(function(){
        $("button").click(function(){
        var div = $("#animacja")
        var ilosc=document.getElementById("#ilosc_rzutow").value;
        div.animate({width:'333px'}, ilosc);
        
        });
    });

1 odpowiedź

+2 głosów
odpowiedź 27 marca 2016 przez niezalogowany
edycja 27 marca 2016

var ilosc=document.getElementById("#ilosc_rzutow").value;

Bez #. Swoją drogą, jak już używasz jQuery - to po prostu:

var ilosc = $("#ilosc_rzutow").val();

Ogólnie cały problem polega na tym, że wszystkie wartości z inputów są pobierane jako stringi. Widać funkcja animate nie dopuszcza do rzutowania argumentów, więc trzeba to zrobić przed ich wysłaniem. Skorzystaj z funkcji parseInt na zmiennej ilosc.

Przekopałem się trochę przez jquery-2.2.2.js, oto co można znaleźć w 6854 linijce:

opt.duration = jQuery.fx.off ? 0 : typeof opt.duration === "number" ?
		opt.duration : opt.duration in jQuery.fx.speeds ?
			jQuery.fx.speeds[ opt.duration ] : jQuery.fx.speeds._default;

Jeśli czas_trwania nie jest liczbą i nie jest elementem obiektu jQuery.fc.speeds, który wygląda tak:

jQuery.fx.speeds = {
	slow: 600,
	fast: 200,

	// Default speed
	_default: 400
};

to przyjmuje wartość _default. Więc czas trwania animacji może być tylko liczbą"slow""fast" lub "_default" - wszystko inne zostanie zamienione na 400.

W sumie to samo podałaby Ci dokumentacja (jQuery animate duration), ale mi się nudzi : P

komentarz 27 marca 2016 przez Comandeer Guru (601,110 p.)
Swoją drogą ten kawałek kodu doskonale pokazuje, że jQuery nie zdobyłoby nagrody w konkursie na ładny, czytelny kod ;)
komentarz 27 marca 2016 przez VDI Początkujący (260 p.)
Dzieki wielkie, teraz już powinno wszystko dzialac :D

Podobne pytania

0 głosów
2 odpowiedzi 304 wizyt
pytanie zadane 3 lutego 2016 w HTML i CSS przez Headhunter Gaduła (4,450 p.)
0 głosów
1 odpowiedź 408 wizyt
pytanie zadane 27 lutego 2016 w HTML i CSS przez Headhunter Gaduła (4,450 p.)
0 głosów
1 odpowiedź 175 wizyt
pytanie zadane 20 lutego 2017 w JavaScript przez Alex.Ironside Stary wyjadacz (14,900 p.)

92,572 zapytań

141,423 odpowiedzi

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

...