Je n'ai pas réussi à faire fonctionner IE8 avec jQuery. Apparemment, il y a un bug avec les animations de position d'arrière-plan jQuery sur IE. Surprise, surprise IE a des problèmes avec quelque chose qui fonctionne sur tous les autres navigateurs modernes.
Ne vous inquiétez pas, j'ai trouvé une solution. Inclus ce script après avoir inclus jQuery et cela résoudra le problème. J'ai essayé de trouver un lien officiel au plugin, mais a renoncé à trouver une mise à jour d'un donc je vais juste poster le fichier:
/**
* @author Alexander Farkas
* v. 1.21
*/
(function($) {
if(!document.defaultView || !document.defaultView.getComputedStyle){ // IE6-IE8
var oldCurCSS = jQuery.curCSS;
jQuery.curCSS = function(elem, name, force){
if(name === 'background-position'){
name = 'backgroundPosition';
}
if(name !== 'backgroundPosition' || !elem.currentStyle || elem.currentStyle[ name ]){
return oldCurCSS.apply(this, arguments);
}
var style = elem.style;
if (!force && style && style[ name ]){
return style[ name ];
}
return oldCurCSS(elem, 'backgroundPositionX', force) +' '+ oldCurCSS(elem, 'backgroundPositionY', force);
};
}
var oldAnim = $.fn.animate;
$.fn.animate = function(prop){
if('background-position' in prop){
prop.backgroundPosition = prop['background-position'];
delete prop['background-position'];
}
if('backgroundPosition' in prop){
prop.backgroundPosition = '('+ prop.backgroundPosition;
}
return oldAnim.apply(this, arguments);
};
function toArray(strg){
strg = strg.replace(/left|top/g,'0px');
strg = strg.replace(/right|bottom/g,'100%');
strg = strg.replace(/([0-9\.]+)(\s|\)|$)/g,"$1px$2");
var res = strg.match(/(-?[0-9\.]+)(px|\%|em|pt)\s(-?[0-9\.]+)(px|\%|em|pt)/);
return [parseFloat(res[1],10),res[2],parseFloat(res[3],10),res[4]];
}
$.fx.step. backgroundPosition = function(fx) {
if (!fx.bgPosReady) {
var start = $.curCSS(fx.elem,'backgroundPosition');
if(!start){//FF2 no inline-style fallback
start = '0px 0px';
}
start = toArray(start);
fx.start = [start[0],start[2]];
var end = toArray(fx.options.curAnim.backgroundPosition);
fx.end = [end[0],end[2]];
fx.unit = [end[1],end[3]];
fx.bgPosReady = true;
}
//return;
var nowPosX = [];
nowPosX[0] = ((fx.end[0] - fx.start[0]) * fx.pos) + fx.start[0] + fx.unit[0];
nowPosX[1] = ((fx.end[1] - fx.start[1]) * fx.pos) + fx.start[1] + fx.unit[1];
fx.elem.style.backgroundPosition = nowPosX[0]+' '+nowPosX[1];
};
})(jQuery);
Le code fonctionne maintenant parfaitement dans IE8. Je n'ai pas pris la peine de tester IE7 car seulement 13% de mon trafic provient d'IE, donc je ne prendrai pas la peine de supporter les anciennes versions .... Trop de mal de tête.
J'ai essayé d'utiliser 0px au lieu de haut et le résultat est le même –
Juste au cas où je suis allé de l'avant et essayé d'utiliser à la place du bas. Il lance toujours la même erreur. –