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 相关文章推荐
JQuery Tips(3) 关于$()包装集内元素的改变
Dec 14 Javascript
js各种验证文本框输入格式(正则表达式)
Oct 22 Javascript
javascript 内存回收机制理解
Jan 17 Javascript
纯Javascript实现Windows 8 Metro风格实现
Oct 15 Javascript
js 判断控件获得焦点的示例代码
Mar 04 Javascript
jQuery验证元素是否为空的两种常用方法
Mar 17 Javascript
javascript实现自动填写表单实例简析
Dec 02 Javascript
JavaScript手机振动API
Jun 11 Javascript
微信js-sdk预览图片接口及从拍照或手机相册中选图接口用法示例
Oct 13 Javascript
thinkphp标签实现bootsrtap轮播carousel实例代码
Feb 19 Javascript
js鼠标跟随运动效果
Mar 11 Javascript
vue使用axios时关于this的指向问题详解
Dec 22 Javascript
原生实现一个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
一周让你学会PHP 不错的学习资料
2009/02/06 PHP
PHP中使用cURL实现Get和Post请求的方法
2013/03/13 PHP
ThinkPHP 5.1 跨域配置方法
2019/10/11 PHP
JavaScript实现简单的时钟实例代码
2013/11/23 Javascript
javascript如何判断输入的url是否正确
2014/04/11 Javascript
node.js中的fs.readlinkSync方法使用说明
2014/12/17 Javascript
浅谈jQuery中的事件
2015/03/23 Javascript
jquery插件bxslider用法实例分析
2015/04/16 Javascript
js重写方法的简单实现
2016/07/10 Javascript
artDialog+plupload实现多文件上传
2016/07/19 Javascript
Angular.js跨controller实现参数传递的两种方法
2017/02/20 Javascript
Bootstrap导航简单实现代码
2017/03/06 Javascript
BootStrap中jQuery插件Carousel实现轮播广告效果
2017/03/27 jQuery
如何编写一个d.ts文件的步骤详解
2018/04/13 Javascript
详解在Angular4中使用ng2-baidu-map的方法
2019/06/19 Javascript
浅析Vue下的components模板使用及应用
2019/11/27 Javascript
python返回昨天日期的方法
2015/05/13 Python
Python的Flask框架中的Jinja2模板引擎学习教程
2016/06/30 Python
python环形单链表的约瑟夫问题详解
2018/09/27 Python
Python爬虫实现验证码登录代码实例
2019/05/10 Python
使用Python实现将list中的每一项的首字母大写
2019/06/11 Python
在jupyter notebook 添加 conda 环境的操作详解
2020/04/10 Python
Radley英国官网:英国莱德利小狗包
2019/03/21 全球购物
阿迪达斯越南官网:adidas越南
2020/07/19 全球购物
关联、聚合(Aggregation)以及组合(Composition)的区别
2012/02/29 面试题
网络工程师的自我评价
2013/10/02 职场文书
董事长秘书岗位职责
2013/11/29 职场文书
员工生日活动方案
2014/08/24 职场文书
解除劳动合同协议书(样本)
2014/10/02 职场文书
2015年秋季学校开学标语
2015/07/16 职场文书
小学运动会宣传稿
2015/07/23 职场文书
2016幼儿园教师年度考核评语
2015/12/01 职场文书
Go 在 MongoDB 中常用查询与修改的操作
2021/05/07 Golang
教你使用Pandas直接核算Excel中快递费用
2021/05/12 Python
React Fragment介绍与使用详解
2021/11/11 Javascript
mysql 体系结构和存储引擎介绍
2022/05/06 MySQL