mirror of
https://github.com/jquery/jquery.git
synced 2024-11-23 02:54:22 +00:00
Fix per-property easing. Fixes #9067
This commit is contained in:
parent
31268449b9
commit
3d1c27d52e
9
src/effects.js
vendored
9
src/effects.js
vendored
@ -191,9 +191,12 @@ jQuery.fn.extend({
|
|||||||
}
|
}
|
||||||
|
|
||||||
// easing resolution: per property > opt.specialEasing > opt.easing > 'swing' (default)
|
// easing resolution: per property > opt.specialEasing > opt.easing > 'swing' (default)
|
||||||
opt.animatedProperties[name] = jQuery.isArray( val ) ?
|
if(jQuery.isArray(val)) {
|
||||||
val[1]:
|
opt.animatedProperties[name] = val[1];
|
||||||
opt.specialEasing && opt.specialEasing[name] || opt.easing || 'swing';
|
prop[name] = val[0];
|
||||||
|
} else {
|
||||||
|
opt.animatedProperties[name] = easing || opt.specialEasing && opt.specialEasing[name] || opt.easing || 'swing';
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( opt.overflow != null ) {
|
if ( opt.overflow != null ) {
|
||||||
|
16
test/unit/effects.js
vendored
16
test/unit/effects.js
vendored
@ -923,9 +923,10 @@ test("jQuery.show('fast') doesn't clear radio buttons (bug #1095)", function ()
|
|||||||
|
|
||||||
test("animate with per-property easing", function(){
|
test("animate with per-property easing", function(){
|
||||||
|
|
||||||
expect(3);
|
expect(5);
|
||||||
stop();
|
stop();
|
||||||
|
|
||||||
|
var data = {a:0,b:0,c:0};
|
||||||
var _test1_called = false;
|
var _test1_called = false;
|
||||||
var _test2_called = false;
|
var _test2_called = false;
|
||||||
var _default_test_called = false;
|
var _default_test_called = false;
|
||||||
@ -934,23 +935,30 @@ test("animate with per-property easing", function(){
|
|||||||
_test1_called = true;
|
_test1_called = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
jQuery.easing["_test2"] = function() {
|
jQuery.easing["_test2"] = function(p) {
|
||||||
_test2_called = true;
|
_test2_called = true;
|
||||||
|
return p;
|
||||||
};
|
};
|
||||||
|
|
||||||
jQuery.easing["_default_test"] = function() {
|
jQuery.easing["_default_test"] = function(p) {
|
||||||
_default_test_called = true;
|
_default_test_called = true;
|
||||||
|
return p;
|
||||||
};
|
};
|
||||||
|
|
||||||
jQuery({a:0,b:0,c:0}).animate({
|
jQuery(data).animate({
|
||||||
a: [100, "_test1"],
|
a: [100, "_test1"],
|
||||||
b: [100, "_test2"],
|
b: [100, "_test2"],
|
||||||
c: 100
|
c: 100
|
||||||
}, 400, "_default_test", function(){
|
}, 400, "_default_test", function(){
|
||||||
start();
|
start();
|
||||||
|
|
||||||
ok(_test1_called, "Easing function (1) called");
|
ok(_test1_called, "Easing function (1) called");
|
||||||
|
|
||||||
ok(_test2_called, "Easing function (2) called");
|
ok(_test2_called, "Easing function (2) called");
|
||||||
|
ok(data.b == 100, "Easing function (2) assigned correct value");
|
||||||
|
|
||||||
ok(_default_test_called, "Easing function (_default) called");
|
ok(_default_test_called, "Easing function (_default) called");
|
||||||
|
ok(data.c == 100, "Easing function (_default) assigned correct value");
|
||||||
});
|
});
|
||||||
|
|
||||||
});
|
});
|
||||||
|
Loading…
Reference in New Issue
Block a user