ползунок jquery со значением над ним, который перемещается с ползунком
Я сделал слайдер с запросом / слайдером и стилизовал его с помощью css. ( http://jsfiddle.net/9qwmX/ )
мне удалось поместить выбранное значение в контейнер div, но теперь я хочу, чтобы контейнер, чтобы "путешествие" соответственно с ползуном.
Я пытался использовать ui.handle
и его css left
свойство, которое является процентом. Но поведение несколько странное: иногда он перемещается с левой стороны слайдера, а иногда со смещением Значение 10px.
вопрос: кто-нибудь знает хороший способ позволить коробке, содержащей скользящее значение, путешествовать с ручкой?
3 ответов
Вы можете просто прикрепить подсказку типа div, которую вы можете добавить к ручке, чтобы она двигалась вместе с ней. Вам просто нужно расположить его с помощью CSS, например:
JS
var initialValue = 2012; // initial slider value
var sliderTooltip = function(event, ui) {
var curValue = ui.value || initialValue; // current value (when sliding) or initial value (at start)
var tooltip = '<div class="tooltip"><div class="tooltip-inner">' + curValue + '</div><div class="tooltip-arrow"></div></div>';
$('.ui-slider-handle').html(tooltip); //attach tooltip to the slider handle
}
$("#slider").slider({
value: initialValue,
min: 1955,
max: 2015,
step: 1,
create: sliderTooltip,
slide: sliderTooltip
});
в CSS всплывающая подсказка заимствована из Twitter bootstrap framework
.tooltip {
position: absolute;
z-index: 1020;
display: block;
padding: 5px;
font-size: 11px;
visibility: visible;
margin-top: -2px;
bottom:120%;
margin-left: -2em;
}
.tooltip .tooltip-arrow {
bottom: 0;
left: 50%;
margin-left: -5px;
border-top: 5px solid #000000;
border-right: 5px solid transparent;
border-left: 5px solid transparent;
position: absolute;
width: 0;
height: 0;
}
.tooltip-inner {
max-width: 200px;
padding: 3px 8px;
color: #ffffff;
text-align: center;
text-decoration: none;
background-color: #000000;
-webkit-border-radius: 4px;
-moz-border-radius: 4px;
border-radius: 4px;
}
Вы можете сделать что-то подобное, чтобы построить то, что вы хотите, я использую event.pageX
var newLeft = 100;
$('#move').text(100).css('margin-left',115);
$("#slider").slider(
{
value:100,
min: 0,
max: 500,
step: 50,
slide: function( event, ui ) {
$( "#slider-value" ).html( ui.value );
var pos = (event.pageX > newLeft)? event.pageX + 8
: event.pageX - 42;
newLeft = event.pageX;
$('#move').text(ui.value).css('margin-left',pos);
}
}
);
вот как бы я это сделал. Чтобы вы начали:
используйте положение "ручки":
var offset = $('.ui-slider-handle .ui-state-default .ui-corner-all"').offset();
var offsetLeft = offset.left;
var offestTop = offset.top;
расположите поле значения слайда с абсолютным позиционированием:
#tijdlijnDatum { position: absolute; }
и сделайте что-нибудь с ним в slide
событие:
$( "#slider" ).slider({
slide: function(event, ui) {
$('#tijdlijnDatum').css({ left: offsetLeft + 'px' }); // etc
}
});