CSS-перетворення поки що неможливо анімувати за допомогою jQuery. Ви можете зробити щось подібне:
function AnimateRotate(angle) {
var $elem = $('#MyDiv2');
$({deg: 0}).animate({deg: angle}, {
duration: 2000,
step: function(now) {
$elem.css({
transform: 'rotate(' + now + 'deg)'
});
}
});
}
Детальніше про зворотний виклик можна прочитати тут: http://api.jquery.com/animate/#step
http://jsfiddle.net/UB2XR/23/
І, до речі: вам не потрібно префіксувати перетворення css3 за допомогою jQuery 1.7+
Оновлення
Ви можете обернути це у jQuery-плагін, щоб полегшити своє життя:
$.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
});
});
};
$('#MyDiv2').animateRotate(90);
http://jsbin.com/ofagog/2/edit
Оновлення2
Я трохи оптимізував його, щоб зробити порядок easing
, duration
і complete
незначний.
$.fn.animateRotate = function(angle, duration, easing, complete) {
var args = $.speed(duration, easing, complete);
var step = args.step;
return this.each(function(i, e) {
args.complete = $.proxy(args.complete, e);
args.step = function(now) {
$.style(e, 'transform', 'rotate(' + now + 'deg)');
if (step) return step.apply(e, arguments);
};
$({deg: 0}).animate({deg: angle}, args);
});
};
Оновлення 2.1
Дякую Matteo, який зазначив проблему з this
-контекстом у повному обсязі- callback
. Якщо це виправлено, прив’язавши зворотний виклик до jQuery.proxy
кожного вузла.
Я додав видання в код раніше з оновлення 2 .
Оновлення 2.2
Це можлива модифікація, якщо ви хочете зробити щось на зразок перемикання обертання вперед-назад. Я просто додав параметр старту до функції і замінив цей рядок:
$({deg: start}).animate({deg: angle}, args);
Якщо хтось знає, як зробити це загальнішим для всіх випадків використання, незалежно від того, хоче він встановити початковий ступінь, будь ласка, внесіть відповідне редагування.
Використання ... досить просте!
В основному у вас є два шляхи досягнення бажаного результату. Але спочатку давайте розглянемо аргументи:
jQuery.fn.animateRotate(angle, duration, easing, complete)
За винятком "кут", всі вони є необов'язковими і повертаються до властивостей за замовчуванням jQuery.fn.animate
:
duration: 400
easing: "swing"
complete: function () {}
1-й
Цей шлях є коротким, але виглядає дещо незрозумілим, чим більше аргументів ми передаємо.
$(node).animateRotate(90);
$(node).animateRotate(90, function () {});
$(node).animateRotate(90, 1337, 'linear', function () {});
2-й
Я вважаю за краще використовувати об'єкти, якщо аргументів більше трьох, тому цей синтаксис є моїм фаворитом:
$(node).animateRotate(90, {
duration: 1337,
easing: 'linear',
complete: function () {},
step: function () {}
});