1
<p>Cost: $<span id="hddValue"></span></p>
<p>Cost2: $<span id="hddValue2"></span></p>

<select id="hdd">
  <option>1000</option>
  <option>2000</option>
  <option>3000</option>
  <option>4000</option>
  <option>5000</option>
</select>

<select id="hdd2">
  <option>1700</option>
  <option>500</option>
  <option>3700</option>
  <option>4300</option>
  <option>5070</option>
</select>

$(function () {
            var select = $('#hdd');
            var slider = $("<div id='slider'></div>").insertAfter(select).slider({
                min: 1,
                max: 5,
                range: "true",
                value: select[0].selectedIndex + 1,
                slide: function (event, ui) {
                    select[0].selectedIndex = ui.value - 1;
              $("#hddValue").text($('#hdd option:selected').text());
             $("#hddValue2").text($('#hdd2 option:selected').text());
                }
            });
        //show start value
        $( "#hddValue" ).html(  $('#slider').slider('value') );
        $( "#hddValue2" ).html(  $('#slider').slider('value') );
        });

谁能帮我这个js脚本?我想要做的是当我移动滑块时,我希望每个选定的值都显示在页面上,如两个选项值“hdd”和“hdd2”所示。

现在发生的情况是,当我移动滑块时只有#hdd 更改,当我在javascript 中添加#hdd2 时,hdd2 html 视图只是冻结到第一个选项并且不会更改。

先感谢您。

4

2 回答 2

1

您的更新方法仅更新两个选择,但使用第一个选择的值。没有尝试过,但它应该看起来像这样,顺便说一句。具有相同 id 的多个元素(您的滑块)是无效的,并且会破坏旧浏览器。

<p>Cost: $<span class="hddvalue"></span></p>
<p>Cost2: $<span class="hddvalue"></span></p>

<select id="hdd">
  <option>1000</option>
  <option>2000</option>
  <option>3000</option>
  <option>4000</option>
  <option>5000</option>
</select>

<select id="hdd2">
  <option>1700</option>
  <option>500</option>
  <option>3700</option>
  <option>4300</option>
  <option>5070</option>
</select>

$(function () {
            var
                $selects = $('#hdd,#hdd2'),
                $values = $('.hddvalue')
            ;
            $selects.each(function (i) {
                var sel = this;
                $("<div class='slider'></div>").insertAfter(select).slider({
                    min: 1,
                    max: 5,
                    range: "true",
                    value: sel.selectedIndex + 1,
                    slide: function (event, ui) {
                        sel.selectedIndex = ui.value - 1;
                       $values.eq(i).text(jQuery(this).find('option:selected').text());
                    }
                });
            });

        //show start value
        $values.eq(0).html(  $('.slider').eq(0).slider('value') );
        $values.eq(1).html(  $('.slider').eq(1).slider('value') );
});
于 2013-04-25T02:59:46.093 回答
0
$(function () {
            var
                $selects = $('#hdd,#hdd2'),
                $values = $('.hddvalue');
            $selects.each(function (i) {
                var sel = this;
                $("<div class='slider'></div>").insertAfter(sel).slider({
                    min: 1,
                    max: 5,
                    range: "true",
                    value: sel.selectedIndex + 1,
                    slide: function (event, ui) {
                        sel.selectedIndex = ui.value - 1;
                       $values.eq(i).text(jQuery(this).find('option:selected').text());
                    }
                });
            });

        //show start value
        $values.eq(0).html(  $('.slider').eq(0).slider('value') );
        $values.eq(1).html(  $('.slider').eq(1).slider('value') );
});
于 2014-02-04T09:44:07.820 回答