首页 技术 正文
技术 2022年11月21日
0 收藏 835 点赞 4,590 浏览 2448 个字

最近做项目用到了treeview。因为涉及到多选的问题,很是棘手,于是乎,我决定查看原生JS,探个究竟。需要引用官方的bootstrap-treeview.js都知道吧,对于所需要引用的,我就不多说了。相信很多人都在网上看到了,有的人说要写showCheckbox:true;有的人又让写multiSelect:true。众说纷纭的,但是本博主试了多次,仍不起作用,最后痛下决心,看源码。要知道,看源码是很费时间的事情。我把部分关键源码贴出来。

关于bootstrap的treeview不显示多选(复选框)的问题,以及联动选择的问题,外加多选后取值关于bootstrap的treeview不显示多选(复选框)的问题,以及联动选择的问题,外加多选后取值关于bootstrap的treeview不显示多选(复选框)的问题,以及联动选择的问题,外加多选后取值关于bootstrap的treeview不显示多选(复选框)的问题,以及联动选择的问题,外加多选后取值

聪明的人一眼就能看出来,default是什么意思?默认。也就是说,在默认的配置里面,并没有showCheckbox:true和multiSelect:true,那么它怎么可能起作用呢???也就是说,你引的JS,并不是你真正想要的。来来来,再来,再看一个JS。

关于bootstrap的treeview不显示多选(复选框)的问题,以及联动选择的问题,外加多选后取值

看到了吗,这个JS才有我们想要的东西。而且十分全。注意,我的这个JS在showCheckbox后面定义的是‘!1’,那么‘!1’代表什么意思呢?给大家普及一个知识吧。大部分浏览器里,0代表false,1代表true,现在,在打开测试页,你就会发现,复选框出来了。

关于bootstrap的treeview不显示多选(复选框)的问题,以及联动选择的问题,外加多选后取值

如果此时你的复选框还是没有出来,说明要么你数据格式不对,要么你引得JS不对,或者人家源码里定义的显示复选框的字段为A,而你偏偏写个B,那就不会出来。如果此时你没有实现复选框,那么你就不必往下看了。

接下来,我们来实现联动勾选的效果。

因为,源码里可以说确实是力量有限,在那么复杂的条件判断下做出来的,已经很厉害了,如果你读一遍,你也会发现,要写个公共的联动效果真的很难!那我们就自己实现吧!这一点,我要感谢网上某个博主,他的思路很好,帮助我实现了。先看下实现部分,再看他思路:

  1. $(‘#tree_ul_id’).treeview({
  2. levels: 1,
  3. expandIcon: ‘glyphicon glyphicon-chevron-right’,
  4. collapseIcon: ‘glyphicon glyphicon-chevron-down’,
  5. nodeIcon: ‘glyphicon glyphicon glyphicon-th-list’,
  6. selectedBackColor: false,
  7. selectedColor: ‘#337AB7’,
  8. showCheckbox: 1,//这里之所以写1,是因为我引得js源码里定义1为true
  9. multiSelect: 1,//这里之所以写1,是因为我引得js源码里定义1为true
  10. data: 这里放它需要的格式的数据,
  11. onNodeChecked: function(event, node) { //选中节点
  12. var selectNodes = getChildNodeIdArr(node); //获取所有子节点
  13. if (selectNodes) { //子节点不为空,则选中所有子节点
  14. $(‘#tree_ul_id’).treeview(‘checkNode’, [selectNodes, { silent: true }]);
  15. }
  16. var parentNode = $(“#tree_ul_id”).treeview(“getNode”, node.parentId);
  17. setParentNodeCheck(node);
  18. },
  19. onNodeUnchecked: function(event, node) { //取消选中节点
  20. var selectNodes = getChildNodeIdArr(node); //获取所有子节点
  21. if (selectNodes) { //子节点不为空,则取消选中所有子节点
  22. $(‘#tree_ul_id’).treeview(‘uncheckNode’, [selectNodes, { silent: true }]);
  23. }
  24. }
  25. });

再来看逻辑原理:

  1. function getChildNodeIdArr(node) {
  2. var ts = [];
  3. if (node.nodes) {
  4. for (x in node.nodes) {
  5. ts.push(node.nodes[x].nodeId);
  6. if (node.nodes[x].nodes) {
  7. var getNodeDieDai = getChildNodeIdArr(node.nodes[x]);
  8. for (j in getNodeDieDai) {
  9. ts.push(getNodeDieDai[j]);
  10. }
  11. }
  12. }
  13. } else {
  14. ts.push(node.nodeId);
  15. }
  16. return ts;
  17. }
  1. function setParentNodeCheck(node) {
  2. var parentNode = $(“#tree_ul_id”).treeview(“getNode”, node.parentId);
  3. if (parentNode.nodes) {
  4. var checkedCount = 0;
  5. for (x in parentNode.nodes) {
  6. if (parentNode.nodes[x].state.checked) {
  7. checkedCount ++;
  8. } else {
  9. break;
  10. }
  11. }
  12. if (checkedCount === parentNode.nodes.length) {
  13. $(“#tree_ul_id”).treeview(“checkNode”, parentNode.nodeId);
  14. setParentNodeCheck(parentNode);
  15. }
  16. }
  17. }

把以上代码直接考进去,然后改下对应的ID就完成了。这里值得一提是遍历子节点时,递归用的却是不错,由于数据量十分庞大,层层迭代,递归是不二之选。请看效果图:

关于bootstrap的treeview不显示多选(复选框)的问题,以及联动选择的问题,外加多选后取值
我故意勾选掉了两个,仍然是我们想要的样子,为此,任务完成。

俗话说,帮人帮到底,送佛送上西。来说说,怎么样多选取值吧。一句话的事:$(‘#tree_ul_id’).treeview(‘getChecked’);

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:8,991
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,505
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,349
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,134
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,766
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,844