如何在下拉菜单中创建复选框?

IT技术 javascript html css
2021-02-28 17:03:18

我想创建一个多选保管箱列表。实际上,我必须使用下拉菜单选择多个选项。当我简单地执行此操作时,如下所示:

<select>
 <option><input type="checkbox"></option>
</select>

然后复选框显示在下拉字段的前面。但我想为每个选项创建它而不是作为一个整体,以便我可以选择多个选项。有没有办法做到这一点?

6个回答

这是一个简单的下拉清单:

var checkList = document.getElementById('list1');
checkList.getElementsByClassName('anchor')[0].onclick = function(evt) {
  if (checkList.classList.contains('visible'))
    checkList.classList.remove('visible');
  else
    checkList.classList.add('visible');
}
.dropdown-check-list {
  display: inline-block;
}

.dropdown-check-list .anchor {
  position: relative;
  cursor: pointer;
  display: inline-block;
  padding: 5px 50px 5px 10px;
  border: 1px solid #ccc;
}

.dropdown-check-list .anchor:after {
  position: absolute;
  content: "";
  border-left: 2px solid black;
  border-top: 2px solid black;
  padding: 5px;
  right: 10px;
  top: 20%;
  -moz-transform: rotate(-135deg);
  -ms-transform: rotate(-135deg);
  -o-transform: rotate(-135deg);
  -webkit-transform: rotate(-135deg);
  transform: rotate(-135deg);
}

.dropdown-check-list .anchor:active:after {
  right: 8px;
  top: 21%;
}

.dropdown-check-list ul.items {
  padding: 2px;
  display: none;
  margin: 0;
  border: 1px solid #ccc;
  border-top: none;
}

.dropdown-check-list ul.items li {
  list-style: none;
}

.dropdown-check-list.visible .anchor {
  color: #0094ff;
}

.dropdown-check-list.visible .items {
  display: block;
}
<div id="list1" class="dropdown-check-list" tabindex="100">
  <span class="anchor">Select Fruits</span>
  <ul class="items">
    <li><input type="checkbox" />Apple </li>
    <li><input type="checkbox" />Orange</li>
    <li><input type="checkbox" />Grapes </li>
    <li><input type="checkbox" />Berry </li>
    <li><input type="checkbox" />Mango </li>
    <li><input type="checkbox" />Banana </li>
    <li><input type="checkbox" />Tomato</li>
  </ul>
</div>

这很好,但它在最新版本的 chrome 中不起作用。您需要更改显示样式。参见:jsfiddle.net/evfnLn0x
2021-04-22 17:03:18
嗨,这在 IE9 中不起作用。有没有机会让它在IE9中工作?
2021-04-22 17:03:18
当用户单击外部时,您可以看到下拉列表吗?
2021-04-23 17:03:18
你想隐藏吗?这就是你的意思吗?如果是这样,我已经做了一些改变。在容器上放置一个 tabindex 并捕获其模糊事件。这是使事情发挥作用的最便宜的方法之一。您只能使用 css3 来做到这一点。或者您可以在文档元素上附加一个事件侦听器。
2021-04-30 17:03:18

这不能仅在 HTML 中完成(将表单元素转换为option元素)。

或者您可以只使用标准select multiple字段。

<select multiple>
  <option value="a">a</option>
  <option value="b">b</option>
  <option value="c">c</option>
</select>
@NaumanAhmad 这个答案已经 5 岁了。随意提出编辑建议。
2021-04-21 17:03:18
您提供的链接已损坏
2021-04-23 17:03:18

var expanded = false;

function showCheckboxes() {
  var checkboxes = document.getElementById("checkboxes");
  if (!expanded) {
    checkboxes.style.display = "block";
    expanded = true;
  } else {
    checkboxes.style.display = "none";
    expanded = false;
  }
}
.multiselect {
  width: 200px;
}

.selectBox {
  position: relative;
}

.selectBox select {
  width: 100%;
  font-weight: bold;
}

.overSelect {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
}

#checkboxes {
  display: none;
  border: 1px #dadada solid;
}

#checkboxes label {
  display: block;
}

#checkboxes label:hover {
  background-color: #1e90ff;
}
<form>
  <div class="multiselect">
    <div class="selectBox" onclick="showCheckboxes()">
      <select>
        <option>Select an option</option>
      </select>
      <div class="overSelect"></div>
    </div>
    <div id="checkboxes">
      <label for="one">
        <input type="checkbox" id="one" />First checkbox</label>
      <label for="two">
        <input type="checkbox" id="two" />Second checkbox</label>
      <label for="three">
        <input type="checkbox" id="three" />Third checkbox</label>
    </div>
  </div>
</form>

您始终可以使用 multiple multiple = "true" 选项与选择标签,但有一个 jquery 插件使它更漂亮。它被称为选择,可以在这里找到

这个小提琴示例可能会帮助您入门

谢谢你。

使用 Bootstrap 和 JQuery 的非常简单的代码,没有任何额外的 javascript 代码:

HTML :

<div class="dropdown">
  <button class="btn btn-secondary dropdown-toggle" type="button" id="dropdownMenuButton" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
    Dropdown button
  </button>
  <form class="dropdown-menu" aria-labelledby="dropdownMenuButton">
    <label class="dropdown-item"><input type="checkbox" name="" value="one">First checkbox</label>
    <label class="dropdown-item"><input type="checkbox" name="" value="two">Second checkbox</label>
    <label class="dropdown-item"><input type="checkbox" name="" value="three">Third checkbox</label>
  </form>
</div>

CSS :

.dropdown-menu label {
  display: block;
}

https://codepen.io/funkycram/pen/joVYBv

^这是一个非常好的选择
2021-05-16 17:03:18