JQuery Mobile滑块字符串而不是数字

时间:2013-08-27 14:14:24

标签: javascript jquery jquery-mobile jquery-mobile-slider

我在我的应用中实现了一个jQuery Mobile Slider。这是代码

<input type="range" name="slider-1" id="slider-1" min="1" max="5" value="1">
<div id="hint"></div>

JS

var text = {1 : "bad", 2 : "okay", 3 : "better"};
var $sliderText = $('#hint');
var refresh = function(e){
    $sliderText.text(text[$( '#slider-1' ).slider('value')]);
};

$( '#slider-1' ).slider({
      slide: refresh,
      change: refresh
});

此滑块带有一个输入字段,其中显示滑块的当前值,例如1,2,3,4,5。我想要字符串而不是数字:1 =坏,2 =好,3 =更好...... 我尝试使用onChange事件,但它不起作用。

我希望有人可以提供帮助吗?

2 个答案:

答案 0 :(得分:0)

尝试:

<强> JS

var text = {
    1: "bad",
    2: "okay",
    3: "better",
    4: "great",
    5: "awesome"
};
var $sliderText = $('#hint');

var refresh = function (e) {
    $sliderText.text(text[$('#slider-1').slider('value')]);
};
$(function () {
    $('#slider-1').slider({
        min: 1,
        max: 5,
        slide: refresh,
        change: refresh
    });
    refresh();
});

<强> HTML

您需要删除type="range",否则它将在JQuery mobile API和jqUI

之间发生冲突
<div id="slider-1"></div>
<div id="hint"></div>

http://jsfiddle.net/techunter/fKcjy/

请注意,JQuery UI滑块从未真正喜欢进入框架

答案 1 :(得分:0)

我用以下代码解决了这个问题:

<input type="range" name="slider-1" id="slider-1" min="1" max="5" value="1">
<div id="hint"></div>

JS:

// Slider Handling
                $( "#slider-1" ).on( 'change', function( event ) {
                       var val = $("#slider-1").val();
                       if(val == 1){
                            $("#hint").empty();
                            $("#hint").append("beschissen");
                       }else if(val == 2){
                            $("#hint").empty();
                            $("#hint").append("naja");
                       }else if(val == 3){
                            $("#hint").empty();
                            $("#hint").append("passt");
                       }else if(val == 4){
                            $("#hint").empty();
                            $("#hint").append("fett");
                       }else if(val == 5){
                            $("#hint").empty();
                            $("#hint").append("geilo");
                       }

                    });