bootstrap treeview 树形菜单带复选框及级联选择功能


Posted in Javascript onJune 08, 2018

具体代码如下所示:

<div id="searchTree"></div> 
 <script>
  var treeData = [{
   text: "Parent 1",
   nodes: [{
    text: "Child 1",
    nodes: [{
     text: "Grandchild 1"
    }, {
     text: "Grandchild 2",
     nodes: [{
      text: "Grandchild 2-1",
      nodes: [{
       text: "Grandchild 2-1-1"
      }, {
       text: "Grandchild 2-2-1",
      }]
     }, {
      text: "Grandchild 1-2",
     }]
    }]
   }, {
    text: "Child 2",
    nodes: [{
     text: "Grandchild 2-1"
    }, {
     text: "Grandchild 2-2",
    }]
   }]
  }, {
   text: "Parent 2",
   id:'11111'
  }, {
   text: "Parent 3"
  }, {
   text: "Parent 4"
  }, {
   text: "Parent 5"
  }];
  var nodeCheckedSilent = false;
  function nodeChecked(event, node) {
   if (nodeCheckedSilent) {
    return;
   }
   nodeCheckedSilent = true;
   checkAllParent(node);
   checkAllSon(node);
   nodeCheckedSilent = false;
  }
  var nodeUncheckedSilent = false;
  function nodeUnchecked(event, node) {
   if (nodeUncheckedSilent)
    return;
   nodeUncheckedSilent = true;
   uncheckAllParent(node);
   uncheckAllSon(node);
   nodeUncheckedSilent = false;
  }
  //选中全部父节点 
  function checkAllParent(node) {
   $('#searchTree').treeview('checkNode', node.nodeId, {
    silent: true
   });
   var parentNode = $('#searchTree').treeview('getParent', node.nodeId);
   if (!("nodeId" in parentNode)) {
    return;
   } else {
    checkAllParent(parentNode);
   }
  }
  //取消全部父节点 
  function uncheckAllParent(node) {
   $('#searchTree').treeview('uncheckNode', node.nodeId, {
    silent: true
   });
   var siblings = $('#searchTree').treeview('getSiblings', node.nodeId);
   var parentNode = $('#searchTree').treeview('getParent', node.nodeId);
   if (!("nodeId" in parentNode)) {
    return;
   }
   var isAllUnchecked = true; //是否全部没选中 
   for (var i in siblings) {
    if (siblings[i].state.checked) {
     isAllUnchecked = false;
     break;
    }
   }
   if (isAllUnchecked) {
    uncheckAllParent(parentNode);
   }
  }
  //级联选中所有子节点 
  function checkAllSon(node) {
   $('#searchTree').treeview('checkNode', node.nodeId, {
    silent: true
   });
   if (node.nodes != null && node.nodes.length > 0) {
    for (var i in node.nodes) {
     checkAllSon(node.nodes[i]);
    }
   }
  }
  //级联取消所有子节点 
  function uncheckAllSon(node) {
   $('#searchTree').treeview('uncheckNode', node.nodeId, {
    silent: true
   });
   if (node.nodes != null && node.nodes.length > 0) {
    for (var i in node.nodes) {
     uncheckAllSon(node.nodes[i]);
    }
   }
  }
  $('#searchTree').treeview({
   showCheckbox: true,
   data: treeData,
   onNodeChecked: nodeChecked,
   onNodeUnchecked: nodeUnchecked
  });
  </script>

总结

以上所述是小编给大家介绍的bootstrap treeview 树形菜单带复选框及级联选择功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
基于JavaScript实现继承机制之调用call()与apply()的方法详解
May 07 Javascript
jquery 添加节点的几种方法介绍
Sep 04 Javascript
2则自己编写的jQuery特效分享
Feb 26 Javascript
AngularJS中监视Scope变量以及外部调用Scope方法
Jan 23 Javascript
用AngularJS来实现监察表单按钮的禁用效果
Nov 02 Javascript
利用Node.js检测端口是否被占用的方法
Dec 07 Javascript
详解element-ui级联菜单(城市三级联动菜单)和回显问题
Oct 02 Javascript
vue中uni-app 实现小程序登录注册功能
Oct 12 Javascript
Vue.js获取手机系统型号、版本、浏览器类型的示例代码
May 10 Javascript
JS实现电脑虚拟键盘打字测试
Jun 24 Javascript
Element Tooltip 文字提示的使用示例
Jul 26 Javascript
vue的项目如何打包上线
Apr 13 Vue.js
原生实现一个react-redux的代码示例
Jun 08 #Javascript
vue项目中使用百度地图的方法
Jun 08 #Javascript
浅谈Vue路由快照实现思路及其问题
Jun 07 #Javascript
JavaScript中click和onclick本质区别与用法分析
Jun 07 #Javascript
jQuery动态移除与增加onclick属性的方法详解
Jun 07 #jQuery
使用Vue-cli 3.0搭建Vue项目的方法
Jun 07 #Javascript
vue 国际化 vue-i18n 双语言 语言包
Jun 07 #Javascript
You might like
微信开发之网页授权获取用户信息(二)
2016/01/08 PHP
php一个文件搞定微信jssdk配置
2016/12/12 PHP
node.js中的socket.io入门实例
2014/04/26 Javascript
jQuery内置的AJAX功能和JSON的使用实例
2014/07/27 Javascript
form.submit()不能提交表单的错误原因及解决方法
2014/10/13 Javascript
JS实现仿中关村论坛评分后弹出提示效果的方法
2015/02/23 Javascript
JavaScript中eval()函数用法详解
2015/12/14 Javascript
js显示动态时间的方法详解
2016/08/20 Javascript
connection reset by peer问题总结及解决方案
2016/10/21 Javascript
解决给dom元素绑定click等事件无效问题的方法
2017/02/17 Javascript
js上传图片预览的实现方法
2017/05/09 Javascript
vue2.0中click点击当前li实现动态切换class
2017/06/21 Javascript
原生js获取left值和top值的三种方法
2017/08/02 Javascript
jquery 键盘事件的使用方法详解
2017/09/13 jQuery
Nuxt.js SSR与权限验证的实现
2018/11/21 Javascript
详解vue.js移动端配置flexible.js及注意事项
2019/04/10 Javascript
vue-dplayer 视频播放器实例代码
2019/11/08 Javascript
antd多选下拉框一行展示的实现方式
2020/10/31 Javascript
python实现图片变亮或者变暗的方法
2015/06/01 Python
用十张图详解TensorFlow数据读取机制(附代码)
2018/02/06 Python
python如何通过twisted实现数据库异步插入
2018/03/20 Python
Python跳出多重循环的方法示例
2019/07/03 Python
Python编写带选项的命令行程序方法
2019/08/13 Python
python 计算两个列表的相关系数的实现
2019/08/29 Python
Python reduce函数作用及实例解析
2020/05/08 Python
Java ExcutorService优雅关闭方式解析
2020/05/30 Python
CSS3 分类菜单效果
2019/05/27 HTML / CSS
HTML5 拖拽批量上传文件的示例代码
2018/03/28 HTML / CSS
HTML5离线缓存在tomcat下部署可实现图片flash等离线浏览
2012/12/13 HTML / CSS
英国著名音像制品和图书游戏购物网站:Zavvi
2016/08/04 全球购物
桥梁与隧道工程专业本科生求职信
2013/10/08 职场文书
小学科学教学反思
2014/01/26 职场文书
中学生社会实践活动总结
2014/07/03 职场文书
初中班干部工作总结
2015/08/10 职场文书
小学语文课《掌声》教学反思
2016/03/03 职场文书
漫画「古见同学有交流障碍症」第25卷封面公开
2022/03/21 日漫