Diskuze: Callback když je CSS animace přerušena
V předchozím kvízu, Online test znalostí JavaScript, jsme si ověřili nabyté zkušenosti z kurzu.
Člen
Zobrazeno 9 zpráv z 9.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí JavaScript, jsme si ověřili nabyté zkušenosti z kurzu.
jak se muze animace prerusit?
Už len to, čo si napísal, sa v jQuery tak nepoužíva. Preto si myslím, že nevieš ako ďalej hlavne preto, že si si to zle navrhol... Ak chceš s jQuery napísať callback ktorý sa vykoná po skončení viacero animácií nad elementom, máš tam konštrukciu $('elm').promise().then(cb) a na stop zas callback nepotrebuješ - proste stopneš animáciu a synchrónne, v ďalšom príkaze vykonáš to, čo si zamýšľal vykonať ako callback.
Toto je príklad, ktorý nad elementom pustí štvorsekundovú animáciu vlastnosti left, ale po dvoch sekundách ju stopne a pustí inú:
$('elm')
.css('position', 'relative')
.animate({left: '+=500'}, 4000)
.delay(2000)
.stop()
.animate({left: 0}, 2000)
A toto je príklad ktorý nad elementom pustí dve nezávislé animácie, naraz - nie po sebe - a vykoná callback potom, keď skončia obe:
$('elm')
.css('position', 'relative')
.animate({left: '+=500'}, 2000)
.animate({top: '+=600'}, {duration: 1800, queue: false})
.promise()
.then(function () {
// toto sa pustí po 2000ms
})
Tieto dva príklady vystihujú podstatu správneho spôsobu, "jQuery way", ako narábať s animáciami.
Moc děkuji za radu. Takhle jsem to měl udělané předtím a právě je u toho jeden problém... Asi jsem svuj problém dostatečně nevysvětlit. Mam checkbox a na ten když kliknu tk se provede nějaká animace (Textu se nastaví opacity na 0 a pak na 1) jenže když na checkbox kliknu víckrát animace se "rozbije" proto jsem chtěl vedět jestli existuje callback, kterej se zavolá při přerušení animace. Díky moc
Daj konkrétny kód. Mám predstavu ako to myslíš, aj ako to vyriešiť. Ale nech netipujem, daj sem kód.
Moc nevím jaký kód přidat řeším právě tu animaci, kterou nemam.... Zde jak to má vypadat kliknu na checkbox a do labelu se mi přičta hodnota, kterou jsem nastavil. Pomocí jquery:
result.html(addedValue+ " Kč");
Když ta mtodle přidám tak bych chtěl, aby se provedla animace toho
labelu. Opacity se nastaví na 0 a potom zpátky na 1, řekněme během jedné
vteřiny. A Právě když to dělám pomocí kódu, který jste mi poslal a já
jsem ho používal také je problém v tom že když začnu hodně klikat tak se
v labelu ukazují nesmyslné hodnoty.
Snad jsem to vysvětlit pochopitelně.
Stále tomu moc nerozumiem... Predpokladajme teda, že na onclick udalosť nad jedným elementom animuješ opacity iného elementu. Ak máš input s labelom definovaný napríklad takto,
<label for="price">Price</label>
<input type="checkbox" id="price">
potom na ňom môžeš robiť animáciu napríklad takto:
function flashLabel () {
var label = 'label[for="' + $(this).attr('id') + '"]'
$(label)
.animate({opacity: 0}, 500)
.animate({opacity: 1}, 500)
}
$('input[type="checkbox"]').on('change', flashLabel.bind(this))
Tam je však možný ten problém so zblbnutím animácie klikaním na checkbox viackrát po sebe. Lenže riešenie je jednoduché:
function flashLabel () {
var label = 'label[for="' + $(this).attr('id') + '"]'
$(label)
.stop() // najskôr zastav predošlú animáciu
.animate({opacity: 0}, 500)
.animate({opacity: 1}, 500)
}
Moc děkuji za radu já jsem to měl podobně, takže jsem program pouze vylepšil pomocí toho bindování. Problém, ale přetrvává...
$(element)
.stop()
.animate({opacity: 0}, 500)
.promise()
.then(function () {
element.html(addSpaces(addedValue) + " Kč") ;
$(this)
.stop()
.animate({opacity: 1}, 500);
});
Je to z toho důvodu, že hodnotu tam nastavuji až po skončení první animace, teda myslím. Opravdu už nevím co s tím...
Zobrazeno 9 zpráv z 9.