2012-07-23 10 views
5

Die Eigenschaft scrollLeft eines div scheint unterschiedliche Werte in verschiedenen Browsern zurückzugeben, wenn die Körperrichtung rtl ist.jQuery.scrollLeft() wenn die Richtung rtl ist - unterschiedliche Werte in verschiedenen Browsern

Ein Beispiel hier gesehen werden - http://jsfiddle.net/auVLZ/2/

body { direction: rtl; } 
div.Container { border: 5px solid #F00; width: 500px; height: 400px; overflow: auto; }  
div.Content { background-color: #00F; width: 900px; height: 380px; }​ 

<div id="divContainer" class="Container"> 
    <div class="Content"></div> 
</div> 
<br /> 
<input id="showScrollLeft" type="button" value="Show ScrollLeft" />​ 

$(document).ready(function() 
{ 
    $("#showScrollLeft").click(function(e) 
    { 
     alert($("div.Container").scrollLeft()); 
    }); 
});​ 

Chrome - der Anfangswert ist 400, und wenn die Bildlaufleiste nach links bewegt, ist es 0.

IE8-0 und 400.

Firefox - 0 und -400.

Was verursacht diesen Unterschied und wie kann er gehandhabt werden?

Bearbeiten: Beachten Sie, dass dies mit dem "normalen" scrollLeft auch geschieht - document.getElementById("divContainer").scrollLeft gibt die gleichen Ergebnisse zurück.

Antwort

4

Obwohl ich hatte gehofft, dass zu vermeiden, habe ich am Ende mit Browser-Erkennung:

function GetScrollLeft(elem) 
{ 
    var scrollLeft = elem.scrollLeft(); 
    if ($("body").css("direction").toLowerCase() == "rtl") 
    { 
     // Absolute value - gets IE and FF to return the same values 
     var scrollLeft = Math.abs(scrollLeft); 

     // Get Chrome and Safari to return the same value as well 
     if ($.browser.webkit) 
     { 
      scrollLeft = elem[0].scrollWidth - elem[0].clientWidth - scrollLeft; 
     } 
    } 
    return scrollLeft; 
} 
+0

Browser-Erkennung ist nicht eine schlechte Sache an sich, IE ist. – jbkkd

+0

Ich kämpfe dieses Problem auch .... machte diese Plunk, um diese kanarische feste scrollLeft, aber nicht scrollIntoView() http://plnr.co/edit/UZvnlq?p=info zu zeigen – Jason

Verwandte Themen