Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/jquery-ui/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
具有设置范围限制的多个jquery ui滑块_Jquery_Jquery Ui_Slider_Range - Fatal编程技术网

具有设置范围限制的多个jquery ui滑块

具有设置范围限制的多个jquery ui滑块,jquery,jquery-ui,slider,range,Jquery,Jquery Ui,Slider,Range,我试图在一个页面上设置多组jquery ui滑块。每个组都将配置为具有设定的范围限制。如果页面上只有一组滑块,下面的代码将按预期工作 当一个页面上有多组滑块时,就会出现问题。当存在多个滑块时,第二个组集将与第一个组中最后选定的滑块一起遵循限制规则。第一个组似乎没有遵循其滑块组的任何限制 脚本代码如下: var uls = document.getElementsByTagName('ul'); for(var i=0;i<uls.length;i++){ if(uls[i].id.inde

我试图在一个页面上设置多组jquery ui滑块。每个组都将配置为具有设定的范围限制。如果页面上只有一组滑块,下面的代码将按预期工作

当一个页面上有多组滑块时,就会出现问题。当存在多个滑块时,第二个组集将与第一个组中最后选定的滑块一起遵循限制规则。第一个组似乎没有遵循其滑块组的任何限制

脚本代码如下:

var uls = document.getElementsByTagName('ul');
for(var i=0;i<uls.length;i++){
if(uls[i].id.indexOf('sliders')==0){

var sliders = $("#sliders" +i+ " .slider");

var size = 1000;
var size_step = 100;

sliders.each(function() {
var value = parseInt($(this).text(), size_step),
  availableTotal = size;

$(this).empty().slider({
  value: 0,
  min: 0,
  max: size,
  range: "max",
  step: size_step,
  animate: 100,
  slide: function(event, ui) {
    // Update display to current value
    $(this).siblings().text(ui.value);

    // Get current total
    var total = 0;

    sliders.not(this).each(function() {
      total += $(this).slider("option", "value");
    });

    // Need to do this because apparently jQ UI
    // does not update value until this event completes
    total += ui.value;
    var max = availableTotal - total;

    // Update each slider
    sliders.not(this).each(function() {
      var t = $(this),
      value = t.slider("option", "value");

      t.slider("option", "max", max + value)
        .siblings().text(value + '/' + (max + value));
      t.slider('value', value);
    });
  }
});
});
}
}
页面代码如下所示:

Slider 1
<ul id="sliders0">
<li>
    <div class="slider"></div>
    <span class="value">0</span>
</li>
<li>
    <div class="slider"></div>
    <span class="value">0</span>
</li>
</ul>
<br><br>
Slider 2
<ul id="sliders1">
<li>
    <div class="slider"></div>
    <span class="value">0</span>
</li>
<li>
    <div class="slider"></div>
    <span class="value">0</span>
</li>
<li>
    <div class="slider"></div>
    <span class="value">0</span>
</li>
</ul>
我在以下位置设置了一个JSFIDLE代码和一个带有两组滑块的示例:


我几天前做了这个插件。它支持多组: