1

我试图在这里避免重复,因为在 SO 周围的任何其他“jQuery 选择菜单”帖子中都没有看到我的问题得到解决。只是希望朝着正确的方向轻推。

我有一组选择框,用于按品牌和型号搜索汽车的结果。当然,第一个<select>是汽车的制造。这个<select>元素是在页面加载时使用 PHP 填充的。选择 Make 后,makeID 将通过 AJAX 传递以检索与所选 Make 相关的模型集。

这一切都很好,我的问题是,当我对我的 Make 列表进行多项选择时,它永远不会刷新第二个<select>框,从而将模型附加到第二个<select>框的许多不同品牌中。

如何刷新第二个<select>框以仅显示与第一个框的选择相关的当前结果<select>

我的 HTML:

<form method="post" action="">
  <p>
    <label for="make">Make</label>
    <select name="make" id="make">
      <?php foreach ($usedMakes->MakeResult as $MakeResult) { ?>
        <option value="<?php echo $MakeResult->makeId; ?>"><?php echo $MakeResult->makeName; ?></option>
      <?php } ?>
    </select>
  </p>
  <p>
    <label for="model">Model</label>
    <select name="model" id="model">
      <option value="" selected>Make a Selection</option>
    </select>
  </p>
  <p>
    <button name="submit" id="submit">&nbsp;Submit&nbsp;</button>
  </p>
</form>

我的 JavaScript:

$("#make").change(function() {
  var makeId = $(this).val();
  $.ajax({
    url: "process.inc.php?makeId=" + makeId,
    type: "GET",
    contentType: "application/json; charset=utf-8",
    dataType: "json",
    success: function (data) {
      for(i = 0 ; i < data.length; i++) {
        var modelId = data[i].ModelResult.modelId;
        var modelName = data[i].ModelResult.modelName;
        var response = "<option value=\"" + modelId + "\">" + modelName + "</option>";
        var appendedData = $(response).insertAfter($("#model option:first-child"));
        $("#model option:first-child").data(appendedData);
      };
    }
  });
});
4

2 回答 2

2

删除选项

$("#model option").remove();  //removes all
$("#model option:gt(0)").remove();  //leaves first item, removes the rest

您应该只在构建整个列表后更新,而不是在 for 循环中

  var list = "":
  for (i = 0 ; i < data.length; i++) {
    var modelId = data[i].ModelResult.modelId;
    var modelName = data[i].ModelResult.modelName;
    list += "<option value=\"" + modelId + "\">" + modelName + "</option>";
  };
  var theSelect = $("#model");
  theSelect.find("option:gt(0)").remove();
  theSelect.append(list);
于 2012-10-02T19:16:50.327 回答
0

只需在每个响应上清空它,然后附加它

试试这个。。

$("#model").empty()  

然后在 ajax 请求中附加新值。

这将确保仅显示当前选择的模型。

于 2012-10-02T19:17:53.893 回答