次のコードは、すべてのブラウザIEで完璧に動作します。いつものように。 この問題が発生する必要があるものです:jQuery:ブラウザ間でHEXからRGBへの計算が異なりますか?
- リンクの上にマウスを移動すると、その リンクの色を取得します。
- そのカラーのRGB値を取得すると、 ベースと見なされるCSSは常に に設定されます。
- 0.5秒
- にわたってにおける新しい軽い影が離れてマウスを移動するときに 色を復元することカラー
- アニメーションの軽い影を決定するために、新しいRGB値を使用して計算を行います元の値
私が言ったように、これまでのところ、IEの場合を除いて、コードは絶対にうまく動作します。新鮮な目を持つ人(そして無傷のヘアライン)がこれを見てもらえますか?違うことができますか?
function getRGB(color) {
// Function used to determine the RGB colour value that was passed as HEX
var result;
// Look for rgb(num,num,num)
if (result = /rgb\(\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*\)/.exec(color)) return [parseInt(result[1]), parseInt(result[2]), parseInt(result[3])];
// Look for rgb(num%,num%,num%)
if (result = /rgb\(\s*([0-9]+(?:\.[0-9]+)?)\%\s*,\s*([0-9]+(?:\.[0-9]+)?)\%\s*,\s*([0-9]+(?:\.[0-9]+)?)\%\s*\)/.exec(color)) return [parseFloat(result[1]) * 2.55, parseFloat(result[2]) * 2.55, parseFloat(result[3]) * 2.55];
// Look for #a0b1c2
if (result = /#([a-fA-F0-9]{2})([a-fA-F0-9]{2})([a-fA-F0-9]{2})/.exec(color)) return [parseInt(result[1], 16), parseInt(result[2], 16), parseInt(result[3], 16)];
// Look for #fff
if (result = /#([a-fA-F0-9])([a-fA-F0-9])([a-fA-F0-9])/.exec(color)) return [parseInt(result[1] + result[1], 16), parseInt(result[2] + result[2], 16), parseInt(result[3] + result[3], 16)];
}
var $oldColour;
// Get all the links I want to target
$('a').not('aside.meta a.notes_link, aside.meta ul li a, section.social_media a, footer a').hover(function() {
//code when hover over
//set the old colour as a variable so we can animate to that value when hovering away
$oldColour = $(this).css('color');
//run the getRGB function to get RGB value of the link we're hovering over
var rgb = getRGB($(this).css('color'));
for (var i = 0; i < rgb.length; i++)
//for each of the 3 HEX values, determine if the value + an increment of 30 (for a lighter colour) is lighter than the max (255)
//if it is, use the HEX value plus the increment, else use the max value
rgb[i] = Math.min(rgb[i] + 30, 255);
//join the new three new hex pairs together to form a sinle RGB statement
var newColor = 'rgb(' + rgb[0] + ',' + rgb[1] + ',' + rgb[2] + ')';
//animate the text link color to the new color.
$(this).animate({'color': newColor}, 500);
}, function() {
//code when hovering away
//animate the colour back using the old colour determined above
$(this).animate({'color': $oldColour}, 500);
});
あなたからのご意見をお待ちしております。
@icyrock - 入力いただきありがとうございます、私は試してみますsetTimeou t idea ... console.logのアイデアに関しては、console.logged自身が死にました:IE以外のブラウザは$ oldColourをRGB値と見なし、IEはそれをHEXと見なします。最初のホバーの後、IEはそれをRGB値と見なします。一口。 –
これが唯一の問題だとすれば、 'rgb'文字列をチェックして、始めにあればrgbを解析し、それ以外の場合は16進数を解析してみてください(ここでのサンプル関数:http://www.linuxtopia.org/ online_books/javascript_guides/javascript_faq/rgbtohex.htm)?あなたが試みることができるもう1つのハックは、このための愚かな要素を "予約"し、 '$(...)css()'があなたに与えたものを読み込み、その要素の 'color' CSS属性をその値に設定し、それはあなたにrgb値を与えるかもしれません。 –
Eish、明らかに私はjQueryのnoobです...理論的には、私はあなたが何を意味しているのか理解していますが、私はそれを行う方法については少しわかりません:) –