欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

html+javascript+bootstrap实现层级多选框全层全选和多选功能

程序员文章站 2023-12-01 13:41:04
想做一个先按层级排序并可以多选的功能,首先倾向于用多层标签式的,直接选定加在文本域里, 查到这文,非常详细,如果大家需要做前面所说的功能,可以参考这个地址,  ...

想做一个先按层级排序并可以多选的功能,首先倾向于用多层标签式的,直接选定加在文本域里, 查到这文,非常详细,如果大家需要做前面所说的功能,可以参考这个地址,

     但是,考虑到如果要做一个选项数不确定、可能非常多,用标签会容易视觉疲劳,同时要求随着选项数的变化,最小程度影响网页布局和效果,于是选择用层级的多选框,也就是设置电脑的那种常见效果。第二层选项可以折叠/展开到第一层下面,用bootstrap的 data-toggle="collapse" data-target="#demo1" 进行关联第二层折叠效果。

     具体代码如下:

<script>
//当第一层选项选定,则该选项下的第二层全部被选定
  function allselect(check_v, checkname) {
    var v_item = document.getelementsbyname(check_v);
    var items = document.getelementsbyname(checkname);
    for (var i = 0; i < items.length; ++i) {
      if (v_item[0].checked) {
        items[i].checked = true;
      }
      else {
        items[i].checked = false;
      }
    }
  }
//当第二层选项全部被选定,则第一层被选定;若第二层选项至少有一个没被选定,则第一层不被选定
  function singleselect2parent(check_v, checkname) {
    var v_item = document.getelementsbyname(check_v);
    var items = document.getelementsbyname(checkname);
    var childstatus = true;
    for (var i = 0; i < items.length; ++i) {
      childstatus = (childstatus && items[i].checked);
    }
    if (childstatus) {
      v_item[0].checked = true;
    }
    else {
      v_item[0].checked = false;
    }
  }
//全选按钮,点击全选,则所有选项被选中
  function allchecked() {
    var inputitems = document.getelementsbyclassname("checkbox2check");
    for (var i = 0; i < inputitems.length; i++) {
      var checkitems = document.getelementsbyname("checkbox" + (i+1));
      for (var j = 0; j < checkitems.length; j++) {
        checkitems[j].checked = true;
      }
      inputitems[i].checked = true;
    }
  }
</script>
<style>
  ul li{
    list-style:none;
  }
</style>
<div>
  <input class="checkbox2check" type="checkbox" checked name="checkbox_v1" value="version1" onclick="allselect('checkbox_v1', 'checkbox1')"><a data-toggle="collapse" data-target="#demo1">版本一<b class="caret"></b></a>
  <ul id="demo1" class="collapse in">
    <li> <input type="checkbox" checked name="checkbox1" value="layer1" onclick="singleselect2parent('checkbox_v1', 'checkbox1')">v1.0.1</li>
    <li> <input type="checkbox" checked name="checkbox1" value="layer2" onclick="singleselect2parent('checkbox_v1', 'checkbox1')">v1.1.1</li>
    <li> <input type="checkbox" checked name="checkbox1" value="layer3" onclick="singleselect2parent('checkbox_v1', 'checkbox1')">v1.2.1</li>
    <li> <input type="checkbox" checked name="checkbox1" value="layer4" onclick="singleselect2parent('checkbox_v1', 'checkbox1')">v1.3.1</li>
  </ul>
</div>
<div>
  <input class="checkbox2check" type="checkbox" checked name="checkbox_v2" value="version2" onclick="allselect('checkbox_v2', 'checkbox2')"><a data-toggle="collapse" data-target="#demo2">版本二<b class="caret"></b></a>
  <ul id="demo2" class="collapse in">
    <li> <input type="checkbox" checked name="checkbox2" value="layer5" onclick="singleselect2parent('checkbox_v2', 'checkbox2')">v2.0.1</li>
    <li> <input type="checkbox" checked name="checkbox2" value="layer6" onclick="singleselect2parent('checkbox_v2', 'checkbox2')">v2.1.1</li>
    <li> <input type="checkbox" checked name="checkbox2" value="layer7" onclick="singleselect2parent('checkbox_v2', 'checkbox2')">v2.2.1</li>
  </ul>
</div>
<div>
  <input class="checkbox2check" type="checkbox" checked name="checkbox_v3" value="version3" onclick="allselect('checkbox_v3', 'checkbox3')"><a data-toggle="collapse" data-target="#demo3">版本三<b class="caret"></b></a>
  <ul id="demo3" class="collapse in">
    <li> <input type="checkbox" checked name="checkbox3" value="layer8" onclick="singleselect2parent('checkbox_v3', 'checkbox3')">v3.0.1</li>
    <li> <input type="checkbox" checked name="checkbox3" value="layer9" onclick="singleselect2parent('checkbox_v3', 'checkbox3')">v3.1.1</li>
    <li> <input type="checkbox" checked name="checkbox3" value="layer10" onclick="singleselect2parent('checkbox_v3', 'checkbox3')">v3.2.1</li>
  </ul>
</div>
<button type="button" onclick="allchecked()">全选</button>

以上所述是小编给大家介绍的html+javascript+bootstrap实现层级多选框全层全选和多选功能,希望对大家有所帮助