Jquery附加麻烦

时间:2012-07-20 09:24:38

标签: javascript jquery jquery-slider

我有一个问题,我有一个附加span元素的js代码。我的问题是它一直在消失,它不是一个bug或什么的。

PS:我正在使用jquery ui slider。我正在做的是使用附加元素(span)显示我的滑块的当前值。唯一的问题是当我点击我的另一个滑块时它会一直消失。

这是我的所有代码: HTML

<div id = "opacity" class="slider-range"></div><br>
<div id = "volume" class="slider-range"></div><br>

的Javascript

var append_element = $('<span></span>');
        $('.slider-range').slider( {
            animate : true,
        });

        $("#opacity").slider({
            min     : 0,
            max     : 100,
            value   : 60,
            step    : 10,
            change  : function(event, ui) {
                slider_value('#opacity', ui.value);
            }
        });

        $("#volume").slider({
            min     : 0,
            max     : 100,
            value   : 20,
            step    : 10,
            change  : function(event, ui) {
                slider_value('#volume', ui.value);
            }
        });

        function slider_value(id, response) {
            append_element.removeClass().appendTo(id);
            //remove '#' / get id
            id = $(id).attr('id');

            var new_span = $('span').addClass('slider-value-'+id);
            $(new_span).html(response);
            console.log(new_span);
        }

任何人。把头发拉到T_T。

感谢。

1 个答案:

答案 0 :(得分:1)

你只是在整个页面使用一个跨度.. 我想如果你不让它消失,你必须使用的不仅仅是一个!

所以你可以使用这段代码:

var append_element = '<span></span>';
    $('.slider-range').slider( {
        animate : true,
    });

    $("#opacity").slider({
        min     : 0,
        max     : 100,
        value   : 60,
        step    : 10,
        change  : function(event, ui) {
            slider_value('#opacity', ui.value);
        }
    });

    $("#volume").slider({
        min     : 0,
        max     : 100,
        value   : 20,
        step    : 10,
        change  : function(event, ui) {
            slider_value('#volume', ui.value);
        }
    });

    function slider_value(id, response) {
        $(id).html(append_element);
        //remove '#' / get id
        id = $(id).attr('id');

        var new_span = $('#'+id+'>span').addClass('slider-value-'+id);
        $(new_span).html(response);
        console.log(new_span);
    }

示例:http://jsfiddle.net/c7myp/