Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Update default useTransitionEnd to true #184

Open
wants to merge 1 commit into
base: master
Choose a base branch
from
Open

Update default useTransitionEnd to true #184

wants to merge 1 commit into from

Conversation

dirkgroenen
Copy link

I've been using this plugin in many projects and in almost every project the animations are much smoother when useTransitionEnd is on true. Especially when a jQuery .stop() is used.

I've been using this plugin in many projects and in almost every project the animations are much smoother when useTransitionEnd is on true. Especially when a jQuery .stop() is used.
@flexphperia
Copy link

It's not working for me: tested on Opera 12.16, Chrome 31, Firefox 26.
Transition end callback is never called when relaying on transitionend event.

@dirkgroenen
Copy link
Author

The reason behind the change is because animations weren't finishing properly (when putting a .stop() in front if the transition). When usetransitionend was set to true they did work perfectly. About the callback; this one also ain't working here. I had to create a custom transitionEnd function.

@rstacruz
Copy link
Owner

The reason it isn't default is that there's almost no guarantee that it will consistently be used. For instance, .css({ left: 0 }).transition({ left: 0 }) will not trigger a transitionEnd event, although a Transit user will expect a callback to fire. I haven't found an easy way to detect if a transition will "not happen".

Any proposals on how to handle this?

@rstacruz
Copy link
Owner

Also, the next version (0.9.10) will fix transitionend not firing in certain browsers.

@flexphperia
Copy link

rstacruz,
are there any plans to introduce 0.9.10 version with transitionEnd support?
Now when plugin relays on timer there are issues that callback is called too early. The same when chaining two transitions, first one is finished too early and we have not smooth transition.

@rstacruz
Copy link
Owner

Hm, I think I'd like to have transitionEnd with a setTimeout fallback. The issue with transitionEnd is that it doesn't fire all the time (eg, .css({padding: 0}).transition({padding: 0})), so it's not a 100% reliable thing.

@flexphperia
Copy link

Yes I have tested it already, but you have also said that: "Also, the next version (0.9.10) will fix transitionend not firing in certain browsers."
About what browser you wrote?

@rstacruz
Copy link
Owner

Whatever uses transitionend (with no prefixes) — I think that'd be the latest Firefox and possibly Chrome/webkits.

@flexphperia
Copy link

I've tested all latest Firefox and Chrome browsers and in all everythings works fine when using transitionEnd. Can you confirm that I understood corectly problems may occur when for eg, .css({padding: 0}).transition({padding: 0}) but in other cases it should work fine?

@rstacruz
Copy link
Owner

Yes: so far that's the only case that persists in my testing.

@flexphperia
Copy link

I have found that in firefox and chrome sometimes when you transitioning Y,
transitionEnd event is called to early (about 100ms).
My solution was to use timer and transitionEnd event and dispatch callback
after one that is later called.
Now I dont have problems with too early callback when using timer only and
everything works nice.

Maybe plugin should check is transitioned property values are the same as
starting values, and manually dispatch callback?
22 cze 2014 17:49 "Rico Sta. Cruz" [email protected] napisał(a):

Yes: so far that's the only case that persists in my testing.


Reply to this email directly or view it on GitHub
#184 (comment)
.

@rstacruz
Copy link
Owner

Good call — definitely something to investigate for 1.0.0.

@troygrosfield
Copy link

Would be nice if the doc was updated to explain the use of the useTransitionEnd property. I spent many hours trying to figure out how to cancel callbacks from running not realizing all I needed to do was set this property to true.

Side note, thanks for the great lib @rstacruz! Hope support is continued and strong moving forward.

@milosdjakonovic
Copy link

It's worth noting that current versions of Chrome (confirmed for 42-45 on Windows ) have various issues firing transitionend, mainly regarding late firing.

You can see it here.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants