Ich benutze Isotope für seine erstaunliche Layout-Funktionen, ich habe einen Anruf, der neue Elemente über Ajax abruft, das entfernt die alten Elemente und fügt die neuen hinzu. Die Animation sieht sehr gut aus, aber ich kann nicht zurückrufen, um an der Animation zu arbeiten.Isotop Ereignisse nicht feuern
Ich versuche, diese auf ihrer Website aus ihrer Dokumentation zu nutzen:
das funktioniert für mich nicht nurjedoch
$grid = $('#grid').isotope({
itemSelector: '.item'
});
$grid.on('arrangeComplete', function(){
console.log('arrangeComplete')
});
:
$grid.on('arrangeComplete', onArrange);
ich es auf diese Weise umgesetzt habe. Das Ereignis wird nie ausgelöst.
Ich habe zwei Funktionen zum Entfernen und das Voranstellen der neuen Elemente:
//Remove
$grid.isotope('remove', removeItems); //removeItems being a var this works fine
//Add
$grid
.prepend(assets)
.isotope('appended', assets)
.isotope('reloadItems')
.isotope({sortby: 'original-order'});
//again this all works fine
Ich bin nicht sicher, ob ich das falsche Ereignis für den Abschluss der Animation verwenden, aber die Mühe, die ich habe, ist, dass keiner von sie scheinen zu schießen.
Im Moment habe ich einen Hack anstelle:
$grid.bind("transitionend", function(){
Der Hack funktioniert, aber seine seine Veranstaltung am Ende jedes Elements Übergang Brennen, die auf Mittel abhängig, wie viele Elemente auf der Seite es wird Feuer für alle ihre Übergänge zu entfernen, und dann alle Übergänge für die nächsten Elemente wird vorangestellt. Das ist offensichtlich ein Problem für mich.
Jede Hilfe oder Hinweise zu diesem Thema würde sehr geschätzt werden.
Haben Sie Ihren Code in eine 'function() {}' oder DOM ready gepackt? –
Ja, sie sind alle in separate Funktionen zum Löschen, Hinzufügen und natürlich zum Initialisieren der Instanz aufgeteilt. Es ist in der Initialisierung, dass ich tatsächlich die '.on ('arrangeComplete' ...' – ThePagan
Ich meine dies: '$ (Dokument) .ready ({$ grid.isotope ({...})})' –