Extend $.animate() to detect CSS transitions for Webkit, Mozilla, IE >= 10 and Opera and convert animations automatically. Compatible with IE6+
Tested with jQuery 1.3.2 to 1.8.0
Properties supported: (more to come)
left : using translate(x, y) or translate3d(x, y, z)
top : using translate(x, y) or translate3d(x, y, z)
right
bottom
opacity
width
height
Note that any properties not mentioned above will simply be handled by the standard jQuery $.animate() method. This plugin adds new functionality without taking any away.
The idea is to simply enhance existing animations with a lightweight 'drop-in' plugin. Those looking for features such as IE transformations & translate() functionality should consider http://plugins.jquery.com/project/2d-transform
The plugin will analyse the properties you're animating on, and select the most appropriate method for the browser in use. This means your transitions on left, top and opacity will convert to a CSS3 transition on Webkit & Mozilla agents that support it, and Opera 10.50+. If the user is on a browser that has no CSS3 transitions, this plugin knows about it and won't get involved. Silent degradation.
Multiple callback mechanisms are created internally to monitor for DOM manipulation and for all 'transitionend' CSS3 events to be picked up. This means you have one neat callback() for the whole animation regardless on whether the plugin is using CSS3, DOM, or both for its animations.
Progressively enhanced CSS3 animations without having to do any browser detection or special CSS, therefore using the same Javascript across your applications and websites.
As this plugin uses CSS3 translate where available, there is an internal callback mechanism to reset the 'left' and/or 'top' properties so that your layout is unaffected.
Usage
Usage is identical to the jQuery animate() function, but it comes with 3 new paramaters, which are totally optional and safe to leave untouched for general use:
avoidTransforms: (Boolean)
By default the plugin will convert left and top animations to the CSS3 style -webkit-transform (or equivalent) to aid hardware acceleration. This functionality can be disabled by setting this to true.
useTranslate3d: (Boolean)
This will be auto-detected and set to true if the browser supports it. Set to true/false to force a specific mode. 3D is recommended for iPhone/iPad development (here's why).
leaveTransforms: (Boolean)
By default if the plugin is animating a left or a top property, the translate (2d or 3d depending on setting above) CSS3 transformation will be used. To preserve other layout dependencies, once the transition is complete, these transitions are removed and converted back to the real left and top values. Set this to true to skip this functionality.
avoidCSSTransitions: (Boolean)
Set this to true to revert to native animate() method, avoiding the plugin entirely. The default for this setting is false, but can be overridden using $.toggleDisabledByDefault()
Useful methods
The following methods have been added to the public jQuery object, which you may or may not find useful:
$.toggle3DByDefault()
Toggle for plugin settings to automatically use translate3d (where available; its safe to set to true even if the browser doesn't support).
Returns new setting
$.toggleDisabledByDefault()
Toggle the plugin to be disabled by default (can be overridden per animation with avoidCSSTransitions described above)
Returns new setting
$.setDisabledByDefault(value)
Explicitly disable or enable the plugin (can be overridden per animation with avoidCSSTransitions described above)
Returns new setting
$(e).translation()
Returns current X and Y coordinates for (e) no matter how the element is being positioned
Returns in the format { x: 0, y: 0 }
Note
Since v0.77, the plugin will now automatically use 3D Translations where supported. To override this functionality, you can either use the parameter above, or run $.toggle3DByDefault();
Changelog
1.11 (08/07/2014):
Merging PR #157, fixes #156 for animating with 0
1.10 (09/04/2014):
Merging PR #153 Don't try to restore values which weren't saved
1.09 (09/04/2014):
Merging PR #154 Added support of AMD and Node.js (via browserify) environments
1.08 (16/01/2014):
Merging PR #147 Access element tag name appropriately
1.07 (06/12/2013):
Other units, beside '%' should also be kept
1.06 (06/12/2013):
Merging PR #140 Do not change a user defined display mode for elements, after show/hide
1.05 (14/08/2013):
Merging PR #124 fix for highcharts clash. Thanks @bensonc!
1.04 (14/08/2013):
Using fix from issue #69 by @rickyk586 to support percentages
1.03 (19/7/2013):
Merge PR #129 (Use originalAnimateMethod if a step callback function is provided.) /thx @lehni
1.02 (8/5/2013):
Fixing use3D default flags. It must explicitly be set to false to disable 3d now, the plugin by default will use it if available. (issue #110)
1.01 (8/5/2013):
Adding appropriate display value for wider range of elements (issue #121 - thanks smacky)
1.0 (8/5/2103):
Fix avoidTransforms: true behaviour for directional transitions
0.99 (5/12/2012):
PR #109 Added support for list-item nodes. FadeIn on tags was omitting the list-style support. (thx @SeanCannon)
0.98 (12/11/2012):
Merging pull request #106 thx @gboysko - checking for ownerDocument before using getComputedStyle
请发表评论