実際、私は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とIE 6でテストされています(そう、古いものでも動作します)