CSS-Transformsはまだ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変換の前にjQuery1.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
Update2
私はの順序を作ってそれを少し最適化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
Update 2から、以前にコードにエディションを追加しました。
アップデート2.2
これは、回転を前後に切り替えるなどの操作を行う場合に可能な変更です。関数に開始パラメーターを追加し、次の行を置き換えただけです。
$({deg: start}).animate({deg: angle}, args);
開始度を設定するかどうかに関係なく、すべてのユースケースでこれをより一般的にする方法を誰かが知っている場合は、適切な編集を行ってください。
使い方は...とても簡単です!
主に、目的の結果を得るには2つの方法があります。しかし、最初に、議論を見てみましょう:
jQuery.fn.animateRotate(angle, duration, easing, complete)
「angle」を除いて、それらはすべてオプションであり、デフォルトのjQuery.fn.animate
-propertiesにフォールバックします。
duration: 400
easing: "swing"
complete: function () {}
1位
この方法は短い方法ですが、渡す引数が多いほど不明確に見えます。
$(node).animateRotate(90);
$(node).animateRotate(90, function () {});
$(node).animateRotate(90, 1337, 'linear', function () {});
2位
引数が3つ以上ある場合はオブジェクトを使用することを好むので、この構文が私のお気に入りです。
$(node).animateRotate(90, {
duration: 1337,
easing: 'linear',
complete: function () {},
step: function () {}
});