从 Bootstrap-Select 下拉组件中取消选择任何选项

Deselect any option from Bootstrap-Select dropdown component

我有一个 Bootstrap-Select 下拉列表,当在文本输入中输入特定字符串时,它会从另一个来源填充。一切正常,默认情况下第一个选项被 select 编辑,我想防止这种情况发生,因此用户必须 select 一个选项。

请在此处查看演示:https://jsfiddle.net/moxxah8r/

代码如下:

<style>
  .form-control,
  .selectpicker {
    width: 220px;
  }

  #postalcode {
    text-transform: uppercase;
    margin-right: 10px;
  }
</style>

<div style="padding: 10px;">
  <div style="display: flex;">
    <input name="postalcode" id="postalcode" type="text" class="form-control" autocomplete="postal-code">
    <select name="address" id="address" class="selectpicker" disabled>
      <option value="0" selected>&nbsp;</option>
    </select>
  </div>
</div>

<script>
  var data = ["1 Street Name", "2 Street Name", "3 Street Name", "4 Street Name", "5 Street Name"];
  $('#postalcode').on('input', function(e) {
    var pattern = new RegExp('^[A-Z]{1,2}[0-9]{1,2} ?[0-9][A-Z]{2}$');
    var text = $('#postalcode').val().toUpperCase();

    if (pattern.test(text)) {
      $('#address').empty();
      $.each(data, function(i, value) {
        $('#address').append($('<option>').text(value).attr('value', value));
      });
      $('#address option').prop('selected', false);
      $('#address').prop('disabled', false);
      $('#address').selectpicker('refresh');
    } else {
      $('#address').empty().append('<option value="0" selected>&nbsp;</option>');
      $('#address').prop('disabled', true);
      $('#address').selectpicker('refresh');
    }
  });
</script>

您可以使用 jQuery 执行此操作。删除任何空白选项标签并在您的活动中调用它:

$('select#address').val([]);

您需要做的第一件事是从预定义的 <option> 中删除 selected,因为这是设计造成的问题,而不是默认情况。

为什么不利用 Bootstrap Select 的一些内置功能,而不是依赖空白的 <option> hack?通过在 <select> 元素中指定 title,您可以创建一个伪占位符。这可以防止默认选择下拉菜单中的第一项:

<select name="address" id="address" class="selectpicker" title="Make Your Selection" disabled>...</select>

您可以在 Bootstrap Select 的自定义按钮文本文档

中阅读有关此功能以及其他几个标签选项的信息

https://silviomoreto.github.io/bootstrap-select/examples/#placeholder