9

我正在使用Bootstrap 多选,我想添加一个选项来取消选中所有选定的选项。请为我提供相同的解决方案。谢谢你的帮助 :)

4

10 回答 10

17

您可以使用此处文档.multiselect('refresh')中提到的方法。bootstrap-multiselect

因此,在多选列表旁边添加一个 HTML 按钮/图标,然后使用以下代码:

$("#reset_client").click(function(){
  $('option', $('#select_client')).each(function(element) {
    $(this).removeAttr('selected').prop('selected', false);
  });
  $("#select_client").multiselect('refresh');
});
<select name="clients[]" multiple="multiple" id="select_client" style="display: none;">
    <option value="multiselect-all"> Select all</option>
    <option value="1">Client 1</option>
    <option value="2">Client 2</option>
    <option value="3">Client 3</option>
    <option selected="selected" value="4">Client 4</option>
    <option selected="selected" value="5">Client 5</option>
    <option value="6">Client 6</option>
    <option selected="selected" value="7">Client 7</option>
    <option value="8">Client 8</option>
</select>

<input type="button" value="Reset" name="reset_clients" id="reset_client" class="reset_button" title="Clear Selection">

于 2015-09-17T17:17:01.330 回答
9

您可以包含一个“全选”按钮,按两次将“取消全选”。为此,请添加此选项:

includeSelectAllOption:true

这将取消所有基于选择元素的引导多选。

function multiselect_deselectAll($el) {
    $('option', $el).each(function(element) {
        $el.multiselect('deselect', $(this).val());
    });
}

$('.multiselect').each(function() {
    var select = $(this);
    multiselect_deselectAll(select);
});

您可以手动添加一个显示“全选”的选项,然后在按下它时调用重置功能。

见: https ://github.com/davidstutz/bootstrap-multiselect/issues/271

于 2015-05-30T15:43:01.883 回答
9

使用下面的代码取消选择多选引导下拉菜单中的所有选择项

$("#ddlMultiSelectId").multiselect('clearSelection');
于 2018-12-05T09:47:01.963 回答
5

您可以使用“deselectAll”方法执行此操作。

$("select.multiselect").multiselect("deselectAll", false);

告诉 jQuery 仅针对您的“选择”非常重要,否则它将失败。这是因为插件添加了具有相同类名的其他内容。

@L_7337 - 这不是您链接到的帖子的副本。这篇文章是关于如何取消选择所有选项,如果你使用Bootstrap Multiselect

另一篇文章是如何从普通的多选选项中取消选择。

最好的问候拉斯穆斯

于 2015-03-27T11:26:38.140 回答
2

如果您有以下多选:

<div class="form-group">
      <label>Choose Skills</label>
      <select id="DDL" name="selValue" class="selectpicker form-control"  multiple>
               <option value="1">One</option>
               <option value="2">Two</option>
               <option value="3">Three</option>
        </select>
  </div>

然后,您可以使用下面的 jQuery 来取消选择所有选项,只需单击一个按钮:

$('#DDL').selectpicker("deselectAll", true).selectpicker("refresh");
于 2018-01-21T22:19:01.067 回答
1

尝试这个:

$("#select_id option:selected").removeAttr("selected");
于 2015-06-18T04:50:39.850 回答
0

你可以这样做,它对我有用:

$('#dropdownID').val([]).multiselect('refresh')
于 2019-06-13T08:04:15.863 回答
0
<!DOCTYPE html>
<html lang="en">
<head>
  <title>Bootstrap Example</title>
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width, initial-scale=1">
  <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
  <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
  <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
</head>
<body>
<div class = "container">
<div class="modal show" id="myModal" role="dialog">
  <div class="modal-dialog">
    <!-- Modal content-->
    <div class="modal-content">
      <div class="modal-header">
        <button class="close" type="button" data-dismiss="modal">×</button>
        <nav class="navbar navbar-default">
  <div>
    <ul class="nav navbar-nav">
      <li class="active"><a href="#">Channel(s)</a></li>
      <li><a href="#">Collaborator(s)</a></li>
    </ul>
  </div>
</nav>
      </div>
      <div class="modal-body">
        <form>              <div class="form-check row">
            <label class="col-sm-2 form-check-label" for="ListeningProject">Listening Project</label>
              <div class="col-sm-10">
                <input class="form-check-input" id="ListeningProject" value="" type="checkbox" />
              </div>
          </div>
          <div class="form-group row">
            <label class="col-sm-2 form-check-label" for="AccountName">Select:</label>
            <div class="col-sm-10">
                <select class="form-control" id="AccountName" multiple="" required="">
                  <option>A Company</option>
                  <option>B Copany</option>
                  <option>C Company</option>
                  <option>D Company</option>
                </select>
            </div>
          </div>
        </form>
      </div>
    </div>
  </div>
</div>
</div>
<script>
$("#ListeningProject").change(function(){  //"select all" change
    var status = this.checked; // "select all" checked status
    $('#AccountName option').prop('selected', status);
});
</script>
</body>
</html>
于 2018-10-22T07:56:24.950 回答
0

该问题已在此处的 gitlab 分叉中修复

它说:

修复了取消全选时触发 onSelectAll

或者,我们可以等待问题 #752得到解决。它仅在一个月前提出。

于 2016-06-30T01:29:41.897 回答
-5

尝试这个

$("option:selected").prop("selected", false)
于 2014-03-27T11:41:50.460 回答