多次完成多个jQuery-UI Sliders的总计

时间:2013-12-15 19:20:49

标签: jquery jquery-ui slider range jquery-ui-slider

我有2个相互依赖的滑块。 2个滑块的最大值为100。如果第一个的值是40%,则第二个的值将被设置为60%。但是,我需要在同一页面上有两组上述场景。我试过了:Jsfiddle

第一组滑块只应该相互依赖,这应该在第二组中复制。但是,我遇到的问题是,第一组滑块中的第一个滑块和第二个滑块会影响第二组滑块。

(HTML):

First set
<ul id="sliders">
    <li>
        <div class="slider">70</div>
        <span class="value">0</span>%
    </li>
    <li>
        <div class="slider">30</div>
        <span class="value" >0</span>%
    </li>
</ul>

second set
<ul id="sliders2">
    <li>
        <div class="slider2">70</div>
        <span class="value">0</span>%
    </li>
    <li>
        <div class="slider2">30</div>
        <span class="value" >0</span>%
    </li>
</ul>

使用Javascript:

var sliders = $("#sliders .slider");
var availableTotal = 100;

sliders.each(function() {
    var init_value = parseInt($(this).text());

    $(this).siblings('.value').text(init_value);

    $(this).empty().slider({
        value: init_value,
        min: 0,
        max: availableTotal,
        range: "max",
        step: 2,
        animate: 0,
        slide: function(event, ui) {

            // Update display to current value
            $(this).siblings('.value').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 delta = availableTotal - total;

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

                var new_value = value + (delta/2) + 1;

                if (new_value < 0 || ui.value == 100) 
                    new_value = 0;
                if (new_value > 100) 
                    new_value = 100;

                t.siblings('.value').text(new_value);
                t.slider('value', new_value);
            });
        }
    });
});

var sliders = $("#sliders2 .slider2");
var availableTotal = 100;

sliders.each(function() {
    var init_value = parseInt($(this).text());

    $(this).siblings('.value').text(init_value);

    $(this).empty().slider({
        value: init_value,
        min: 0,
        max: availableTotal,
        range: "max",
        step: 2,
        animate: 0,
        slide: function(event, ui) {

            // Update display to current value
            $(this).siblings('.value').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 delta = availableTotal - total;

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

                var new_value = value + (delta/2) + 1;

                if (new_value < 0 || ui.value == 100) 
                    new_value = 0;
                if (new_value > 100) 
                    new_value = 100;

                t.siblings('.value').text(new_value);
                t.slider('value', new_value);
            });
        }
    });
});

我的预感是var sliders = $("#sliders2 .slider2");无法检索第二组滑块......

------ ----解决 我已将我的代码编辑为Swires指出的内容。还将代码更新为数学部分的正确公式。新小提琴:The correct version

1 个答案:

答案 0 :(得分:-1)

当我遇到这种情况时,我讨厌它,你可能只需要另外一套眼睛。您已将两组滑块设置为变量:

var sliders

将第二个更改为此小提琴中的sliders2:http://jsfiddle.net/e8fCy/1/并且它按预期工作。

编辑在进一步检查时,您的数学也可能已关闭,稍后会检查。