Проблема возникает из-за того, что ваш дескриптор настроен на выход за пределы своего контейнера.
Две проблемы возникают из следующих
.ui-slider .ui-slider-handle {
width:180px;
margin-left:-90px;
}
Во второй строке говорится, чтоползунку разрешено идти на 90px раньше, чем слева от его первоначального контейнера (отсюда и левое переполнение)
А если установить левую часть ручки на 100%, это означает, что он переполнится справа от 90px (180-90).
То, как я справился бы с этим, должно было бы опустить margin-left:-90px;
, уменьшить ширину прокрутки div на 180px и использовать другой div для отображения изображения полосы прокрутки (расположено подваш скользящий div, но шире).
Что-то вроде:
.slider {
width: 362px;
height: 17px;
margin-top: 140px;
margin-left: 5px;
padding: 1px;
position: relative;
}
.ui-slider .ui-slider-handle {
width:180px;
}
.sliderImg{
background: url(productbrowser_scrollbar_20070622.png) no-repeat;
/*add css to position it correctly here*/
}
РЕДАКТИРОВАТЬ: Чтобы ответить на ваш комментарий, следующее исправление CSS на вашей странице должнозаставить эту работу:
.slider {
/*let the rest as is*/
margin-left: 90px;
}
.ui-slider .ui-slider-handle {
width:180px;
margin-left:-90px;
}
Эта комбинация позволит ему с теми же границами (-90 + 90 = 0), но собирается заставить его двигаться хорошо.
EDIT2:
, чтобы включитьнажмите на ручку, вам нужно будет указать высоту handle
(иначе вы не сможете нажать на нее).Однако это переместит ваш промежуток под скользящим делителем, чтобы преодолеть его, вам нужно будет указать их верхнюю позицию (так как у вас они уже есть в абсолюте, это просто ;)
).
Следующее должно быть сделано.
.handle {
height: 100%;
}
.slider span {
/*let the rest as is*/
top: 0;
}
Чтобы это работало выше диапазона, вам нужно немного изменить HTML-код следующим образом:
<div class="handle">
<span id="slider-tags" class="slider-lbl1">Our Books</span>
<span id="slider-tags" class="slider-lbl2">Other Books</span>
</div>