На самом деле у меня есть решение, для которого требуется только jQuery 1.3x, и нет дополнительного плагина.
Сначала добавьте следующие функции в ваш скрипт
function easeInOut(minValue,maxValue,totalSteps,actualStep,powr) {
var delta = maxValue - minValue;
var stepp = minValue+(Math.pow(((1 / totalSteps)*actualStep),powr)*delta);
return Math.ceil(stepp)
}
function doBGFade(elem,startRGB,endRGB,finalColor,steps,intervals,powr) {
if (elem.bgFadeInt) window.clearInterval(elem.bgFadeInt);
var actStep = 0;
elem.bgFadeInt = window.setInterval(
function() {
elem.css("backgroundColor", "rgb("+
easeInOut(startRGB[0],endRGB[0],steps,actStep,powr)+","+
easeInOut(startRGB[1],endRGB[1],steps,actStep,powr)+","+
easeInOut(startRGB[2],endRGB[2],steps,actStep,powr)+")"
);
actStep++;
if (actStep > steps) {
elem.css("backgroundColor", finalColor);
window.clearInterval(elem.bgFadeInt);
}
}
,intervals)
}
Далее, вызовите функцию, используя это:
doBGFade( $(selector),[245,255,159],[255,255,255],'transparent',75,20,4 );
Я позволю вам угадать параметры, они довольно понятны. Если честно, скрипт не от меня, я взял его на странице и изменил, чтобы он работал с последней версией jQuery.
Примечание: протестировано на Firefox 3 и 6 (да, это работает и на этой старой вещи)