4

我正在使用 jQuery ui-slider。在范围滑块中,如果我使用两个手柄选择相同的范围,则一个手柄隐藏在另一个手柄后面。如果选择了相同的范围,我只想满足两个手柄。请帮助我。

$("#dvSliderRange2").slider({
    range: true,
    min: 0,
    max: 100,
    values: [20, 40],
    step: 10,
    slide: function(event, ui) {
        if (ui.values[0] == ui.values[1]) {
            return false;
        }
        $("#lblRange2").text(ui.values[0] + " - " + ui.values[1]);
    }
});​
4

1 回答 1

1

我有一个使用下面一些 css 的解决方案。当它们相等时,这会向元素添加一个类。Css 然后定位这些句柄,使它们都可见。

http://jsfiddle.net/dhQk/jTx89/

但是,在交互性的情况下。如果不对滑块代码进行一些修改,这是不可能的。我已经包含了来自 jquery 滑块 1.10.2 的 src。从 src 的第 176 行开始。

this.handles.each(function( i ) {
    var thisDistance = Math.abs( normValue - that.values(i) );
    if (( distance > thisDistance ) ||
        ( distance === thisDistance &&
            (i === that._lastChangedValue || that.values(i) === o.min ))) {
        distance = thisDistance;
        closestHandle = $( this );
        index = i;
    }
});

正如您从中可以看到的,它实际上不是由您选择的手柄选择的,而是通过您单击的距离以编程方式选择的。不知道为什么决定他们会这样做,但是一旦它们具有相同的值,它就不允许您单独与它们交互;

于 2013-04-13T00:25:47.077 回答