在JQuery UI范围滑块

时间:2015-06-23 13:38:35

标签: jquery-ui jquery-ui-slider

我正在使用jQuery UI滑块,发现两个与我非常相似的示例。 但是,第一个滑块允许将手柄拖到另一侧的另一个手柄,而在第二个滑块中,手柄似乎相互阻挡(即你不能将左手柄拖到右手柄的右侧)反之亦然。)

有人可以向我解释,为什么会这样?

这是小提琴:http://jsfiddle.net/w4gy8p1v/1/

滑块代码:

$(document).ready(function() {
    $("#slider").slider({
        min: 0,
        max: 100,
        step: 1,
        values: [10, 90],
        slide: function(event, ui) {
            for (var i = 0; i < ui.values.length; ++i) {
                $("input.sliderValue[data-index=" + i + "]").val(ui.values[i]);
            }
        }
    });

    $("input.sliderValue").change(function() {
        var $this = $(this);
        $("#slider").slider("values", $this.data("index"), $this.val());
    });
});
<form>
    <div>
        <input type="text" class="sliderValue" data-index="0" value="10" />
        <input type="text" class="sliderValue" data-index="1" value="90" />
    </div>
    <br />
    <div id="slider"></div>
</form>

第二个滑块的代码:

  $(function() {
    $( "#slider-range" ).slider({
      range: true,
      min: 0,
      max: 500,
      values: [ 75, 300 ],
      slide: function( event, ui ) {
        $( "#amount" ).val( "$" + ui.values[ 0 ] + " - $" + ui.values[ 1 ] );
      }
    });
    $( "#amount" ).val( "$" + $( "#slider-range" ).slider( "values", 0 ) +
      " - $" + $( "#slider-range" ).slider( "values", 1 ) );
  });
<p>
  <label for="amount">Price range:</label>
  <input type="text" id="amount" readonly style="border:0; color:#f6931f; font-weight:bold;">
</p>

<div id="slider-range"></div>

1 个答案:

答案 0 :(得分:3)

差异来自range选项(range: true)。

当range选项为true时,滑块手柄无法交叉。