Home >Web Front-end >CSS Tutorial >How Can I Achieve Cross-Browser CSS Rotation Animations with jQuery?

How Can I Achieve Cross-Browser CSS Rotation Animations with jQuery?

Barbara Streisand
Barbara StreisandOriginal
2024-12-04 03:05:11639browse

How Can I Achieve Cross-Browser CSS Rotation Animations with jQuery?

Cross-Browser CSS Rotation with jQuery.animate()

Problem:

Performing CSS rotation animations using jQuery.animate() fails to work cross-browser. The rotation works when using .css(), but not when using .animate().

Cause:

CSS-Transforms cannot be directly animated with jQuery.

Solution:

To perform CSS-Transform animations using jQuery, you can use the following alternative method:

function AnimateRotate(angle) {
    var $elem = $('#MyDiv2');
    $({deg: 0}).animate({deg: angle}, {
        duration: 2000,
        step: function(now) {
            $elem.css({
                transform: 'rotate(' + now + 'deg)'
            });
        }
    });
}

Explanation:

This method uses a custom "step" callback function to update the "transform" property of the selected element at each step of the animation. The "step" function receives the current animation position (now) as a parameter, which you can use to calculate the desired rotation angle.

Plugin:

You can wrap this method into a jQuery plugin for easier use:

$.fn.animateRotate = function(angle, duration, easing, complete) {
    return this.each(function() {
        var $elem = $(this);
        $({deg: 0}).animate({deg: angle}, {
            duration: duration,
            easing: easing,
            step: function(now) {
                $elem.css({
                   transform: 'rotate(' + now + 'deg)'
                 });
            },
            complete: complete || $.noop
        });
    });
};

Usage:

To use the plugin, you can simply call:

$('#MyDiv2').animateRotate(90);

Updates:

The provided solution has been updated several times to improve efficiency and provide more flexibility.

  • Update 2: Optimized to make the order of arguments insignificant.
  • Update 2.1: Fixed a context issue with the complete callback.
  • Update 2.2: Added a start parameter for toggling animations.

Additional Usage Details:

  • The animateRotate function accepts several optional parameters, including duration, easing, and complete, with default values provided.
  • The user can provide these parameters in various ways, either as positional arguments or as an object.
  • The "step" function provides additional control over the rotation at each animation step.

The above is the detailed content of How Can I Achieve Cross-Browser CSS Rotation Animations with jQuery?. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn