0

我只是想知道如何根据用户在start period中选择的内容更新长度值。

例如,如果用户选择 09:00 - 09:50,则开始时段具有选项 1-7。

如果用户选择 10:00 - 10:50,则开始时段有选项 1-6。

...

如果用户选择 17:00 - 17:50,则开始时段有选项 1。

我将如何使用 javascript 实现这一目标?

到目前为止,这是我的代码:

http://jsfiddle.net/RmXuH/

<p>
  <label>Start Period</label>
  <select onchange="reloadRoomPreference();" id = "edit_req_start" name="">
    <option>09:00 - 09:50</option>
    <option>10:00 - 10:50</option>
    <option>11:00 - 11:50</option>
    <option>12:00 - 12:50</option>
    <option>13:00 - 13:50</option>
    <option>14:00 - 14:50</option>
    <option>15:00 - 15:50</option>
    <option>16:00 - 16:50</option>
    <option>17:00 - 17:50</option>
  </select>
</p>
<p>
  <label>Length</label>
  <select onchange="reloadRoomPreference();" id = "edit_req_length" name="">
    <option>1</option>
    <option>2</option>
    <option>3</option>
    <option>4</option>
    <option>5</option>
    <option>6</option>
    <option>7</option>
  </select>
</p>
4

1 回答 1

1

像这样的事情:

<p>
  <label>Start Period</label>
  <select onchange="reloadRoomPreference();" id = "edit_req_start" name="">
    <option value="0">09:00 - 09:50</option>
    <option value="1">10:00 - 10:50</option>
    <option value="2">11:00 - 11:50</option>
    <option value="3">12:00 - 12:50</option>
    <option value="4">10:00 - 13:50</option>
    <option value="5">14:00 - 14:50</option>
    <option value="6">15:00 - 15:50</option>
    <option value="7">16:00 - 16:50</option>
    <option value="8">17:00 - 17:50</option>
  </select>
</p>
<p>
  <label>Length</label>
  <select onchange="reloadRoomPreference();" id = "edit_req_length" name="">
  </select>
</p>

Javascript:

var optionsValue = [1, 2, 3, 4, 5, 6, 7] //Contains the values displayed in the second dropdown

//Populate with all the values
for (var i = 0; i < optionsValue.length ; i++)
    $('#edit_req_length').append('<option>' + optionsValue[i] + '</option>');

//Triggered each time you change the first dropdown
$('#edit_req_start').on('change', function(data) {
    var options = $(this).children('option');
    $('#edit_req_length').empty();
    for (var i = 0; i < optionsValue.length - $(this).val() ; i++)
        //This way, we don't have any empty value
        if (i >= optionsValue.length)
            $('#edit_req_length').append('<option>' + optionsValue[optionsValue.length - 1] + '</option>');
        else
            $('#edit_req_length').append('<option>' + optionsValue[i] + '</option>');
});

JSFiddle在这里:http: //jsfiddle.net/hda7f/

但是您在第一个下拉列表中的值比在第二个下拉列表中的值多,因此我添加了一个条件以在第二个下拉列表中保留至少一个项目。

于 2013-05-12T22:45:46.290 回答