In realtà, ho una soluzione che richiede solo jQuery 1.3x e nessun plug-in aggiuntivo.
Innanzitutto, aggiungi le seguenti funzioni al tuo script
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)
}
Quindi, chiama la funzione usando questo:
doBGFade( $(selector),[245,255,159],[255,255,255],'transparent',75,20,4 );
Ti lascio indovinare i parametri, sono abbastanza autoesplicativi. Ad essere onesti lo script non è mio, l'ho preso su una pagina e poi l'ho cambiato in modo che funzioni con l'ultimo jQuery.
NB: testato su firefox 3 e ie 6 (sì, funziona anche su quella vecchia cosa)