这有点像此处发布的问题:Yes or no toggle or slider - 但我无法在此示例中找到解决方案。
我有一个水平增量范围滑块我想修改,以便标签被解码为小 - 中 - 大,值为1 - 2 - 3
我已经尝试过坚持使用数组进行解码,但我无法让它正常工作。
这是我到目前为止所拥有的:
<script>
$(function() {
$( "#slider-range" ).slider({
range: true,
min: 1,
max: 3,
step: 1,
values: [ 2, 3 ],
slide: function( event, ui ) {
$( "#amount" ).val( ui.values[ 0 ] + " - " + ui.values[ 1 ] );
}
});
$( "#amount" ).val( $( "#slider-range" ).slider( "values", 0 ) +
" - " + $( "#slider-range" ).slider( "values", 1 ) );
});
</script>
因此,如果选择了位置2 - 3(默认情况下),则标签将显示为“中 - 大”。
非常感谢任何帮助或指示!
由于
答案 0 :(得分:2)
它使用mapper对象而不是数组,但也包含一个返回字符串而不是自己创建的函数:
$(function() {
// mapper
var valueMap = {
1 : "small",
2 : "medium",
3 : "large",
getText : function(arr) {
return this[arr[0]] + " - " + this[arr[1]];
}
};
// initial range slider values
var initial = [2, 3];
// initialize slider
$( "#slider-range" ).slider({
range: true,
min: 1,
max: 3,
step: 1,
values: initial,
slide: function( event, ui ) {
$("#amount").val(valueMap.getText(ui.values));
}
});
// initialize value display
$("#amount").val(valueMap.getText(initial));
});