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.
Browser-Erkennung ist nicht eine schlechte Sache an sich, IE ist. – jbkkd
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