树形下拉框ztree、获取ztree所有父节点,ztree的相关方法
参考:jQuery树形控件zTree使用小结
需求
添加、修改的终端需要选择组织,组织是多级架构(树状图显示)。
思路
1、因为下拉框需要树状图显示,所以排除使用select做下拉框,改用input 模拟下拉框
2、树状图采用zTree插件
开始
1、布局
<script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
<script src="https://cdn.bootcss.com/zTree.v3/3.5.33/js/jquery.ztree.core.min.js"></script>
<link href="https://cdn.bootcss.com/zTree.v3/3.5.33/css/zTreeStyle/zTreeStyle.min.css" rel="stylesheet">
<style>
.trg{/*设置三角符号的样式*/
width: 0;
height: 0;
border-left: 6px solid transparent;
border-right: 6px solid transparent;
border-top: 6px solid black;;
position: absolute;
left:380px;
top:12px;
}
.org-select{/*设置input框的样式*/
cursor: default;
z-index: -1;
width:400px;
}
#treeDemo{/*设置树结构的样式*/
position:absolute;
z-index:1;/*层级定位高一些,absolute或者relative时,显示层级的优先级*/
overflow:hidden;/*去除浮动*/
background-color: white;/*背景色*/
width:100%;
border:1px solid #4aa5ff;
}
</style>
<div style="position: relative;margin:90px;">
<input id="orgName" class="org-select" onclick="showTree()" readonly >
<!-- 模拟select点击框 以及option的text值显示-->
<i class="trg"style="position: absolute;"></i>
<!-- 模拟select右侧倒三角 -->
<input id="orgCode" type="hidden" name="orgCode" />
<!-- 存储 模拟select的value值 -->
<div class="ztree" style="display:none; position: absolute;border:1px solid #4aa5ff;width:200px;">
<ul id="treeDemo"></ul>
<!-- zTree树状图 相对定位在其下方 -->
</div>
</div>
2、js代码
//树状图展示
var orgList =[
{ id:1, pId:0, name:"父节点1 - 展开", open:true},
{ id:11, pId:1, name:"父节点11 - 折叠"},
{ id:111, pId:11, name:"叶子节点111"},
{ id:112, pId:11, name:"叶子节点112"},
{ id:113, pId:11, name:"叶子节点113"},
{ id:114, pId:11, name:"叶子节点114"},
{ id:12, pId:1, name:"父节点12 - 折叠"},
{ id:121, pId:12, name:"叶子节点121"},
{ id:122, pId:12, name:"叶子节点122"},
{ id:123, pId:12, name:"叶子节点123"},
{ id:124, pId:12, name:"叶子节点124"}
];
/*两种格式都可以*/
var orgList =[
{ name:"***平台系统", open:true,
children: [
{ name:"**核心系统", open:true,
children: [{ name:"数据维护系统" }
,{ name:"新数据维护系统" }
]}
,{ name:"北分车险****" }
,{ name:"北京上海易*****" } ]}
,{ name:"**增项目" }
,{ name:"客服体系" }
];
var setting = {
data: {
simpleData: {
enable: true
}
},
//回调
callback: {
onClick: zTreeOnClick
},
view: {
fontCss: { fontSize: "14px" }
}
};
//节点点击事件
function zTreeOnClick(event, treeId, treeNode) {
name = getFilePath(treeNode);
$('#orgName').val(name);
hideTree();
};
//获取子节点,所有父节点的name的拼接字符串
function getFilePath(treeObj){
if(treeObj==null)return "";
var filename = treeObj.name;
var pNode = treeObj.getParentNode();
if(pNode!=null){
filename = getFilePath(pNode) +">"+ filename;
}
return filename;
}
$(document).ready(function () {
//初始组织树状图
$.fn.zTree.init($("#treeDemo"), setting, orgList);
});
//下拉框显示 隐藏
function showTree(){
if($('.ztree').css('display') == 'none'){
$('.ztree').css('display','block');
} else{
$('.ztree').css('display','none');
}
$("body").bind("mousedown", onBodyDownByActionType);
}
function hideTree() {
$('.ztree').css('display','none');
$("body").unbind("mousedown", onBodyDownByActionType);
return false;
} //区域外点击事件
function onBodyDownByActionType(event) {
if (event.target.id.indexOf('treeDemo') == -1){
if(event.target.id != 'selectDevType'){
hideTree();
}
}
}
3、展示

zTree的常用方法
1 获取zTree对象:var treeObj = $.fn.zTree.getZTreeObj("tree");
2 增加节点:addNodes(parentNode,index,newNodes,isSlient)
3 parentNode:指定的父节点,如果增加根节点,请设置 parentNode 为 null 即可
4 index:新节点插入的位置(从 0 开始),index = -1 时,插入到最后,此参数可忽略
5 newNodes:需要增加的节点数据 JSON 对象集合,数据只需要满足 zTree 的节点数据必需的属性即可
6 isSilent:true 时,添加节点后不展开父节点,其他值或缺省状态都自动展开
7 勾选或取消勾选全部节点:checkAllNodes(checked);
8 checked参数为true时全部勾选,为false时全部取消勾选。
9 勾选或取消勾选单个节点:checkNode(node, checked, checkedTypeFlag,callbackFlag);
10 node:要进行操作的节点
11 checked:为true勾选,为false取消勾选
12 checkeTypeFlag:为true表示对当前结点的子节点及父节点进行勾选状态的联动,为false不联动
13 callbackFlag:为true时表示执行beforeOnCheck和onCheck事件的回调函数,为false不执行
14 getParentNode:找到父节点
编辑节点
15 edit(node); 使节点处于编辑状态,必须引用jquery.ztree.exedit 扩展。
16 展开或折叠全部节点:expandAll(expand);
17 expand为true是展开所有节点,为false是折叠所有节点。
18 根据节点属性查找结点:getNodesByParam(key,value, parentNode);
19 key:属性名
20 value:属性值
21 parentNode:是否在指定节点下查找,为null表示整个树查找。
22 获取被勾选或未被勾选的节点集合:getCheckedNodes(checked);
23 checked为true表示获取所有被勾选的节点集合,为false表示所有未被勾选的节点集合
24 获取输入框勾选状态被改变的节点集合:getChangeCheckedNodes()


树形下拉框ztree、获取ztree所有父节点,ztree的相关方法的更多相关文章
- Ext5实现树形下拉框ComboBoxTree
最近为了实现一个属性下拉框被Ext框架折腾了好几天.. 所以,首先要说的是,不管你要做什么系统.强烈建议你不要选择Ext.据我这几天的搜索,应该这个框架现在用的人也很少了. Ext框架的缺陷:框架沉重 ...
- easyui源码翻译1.32--ComboTree(树形下拉框)
前言 扩展自$.fn.combo.defaults和$.fn.tree.defaults.使用$.fn.combotree.defaults重写默认值对象.下载该插件翻译源码 树形下拉框结合选择控件和 ...
- Vue实现树形下拉框
Vue自身并没有实现树形下拉框的组件,找了很多资料,最后在Github上找了个插件vue-treeselect,功能还是比较全的,模糊搜索.多选.延迟加载.异步搜索.排序,自定义.Vuex支持等等.这 ...
- 雷林鹏分享:jQuery EasyUI 表单 - 创建树形下拉框
jQuery EasyUI 表单 - 创建树形下拉框 树形下拉框(ComboTree)是一个带有下列树形结构(Tree)的下拉框(ComboBox).它可以作为一个表单字段进行使用,可以提交给远程服务 ...
- Dorado开发——树形下拉框
最近在学习Dorado开发的过程中,遇到了一个问题,Dorado的树形下拉框选择:Dorado默认情况下父节点和子节点都是可选的,而我要实现的是父节点不可选. 解决办法:在下拉框中,判断父子节点,点击 ...
- flask中单选、多选、下拉框的获取
1.单选: source = request.form.get('source') 2.多选: joy = request.form.getlist('joy') 或者 joy = re ...
- jquery.editable-select 可编辑下拉框之获取select值和input值
使用jquery.editable-select可以实现可编辑下拉框的功能,但需要先导入jquery.js,jquery.editable-select.css,jquery.editable-sel ...
- easyui-conbotree树形下拉框。。。转
最近一直在研究这个树形的下拉选择框,感觉非常的有用,现在整理下来供大家使用: 首先数据库的表架构设计和三级菜单联动的表结构是一样,(父子关系) 1.下面我们用hibernate建一下对应的额实体类: ...
- layui 下拉框 动态获取数据
$(function(){var grade=$("#grade");grade.append("一年级"); //添加下拉列表grade.append(&qu ...
随机推荐
- QQ发起聊天
QQ推广 网址: http://shang.qq.com/v3/widget.html 一键加群 实例: <a target="_blank" href="//sh ...
- [转]使用HttpOnly提升Cookie安全性
原文:https://www.cnblogs.com/zlhff/p/5477943.html 在介绍HttpOnly之前,我想跟大家聊聊Cookie及XSS. 随着B/S的普及,我们平时上网都是依赖 ...
- sklearn 线性回归
# import numpy as np import pandas as pd from pandas import Series,DataFrame import matplotlib.pyplo ...
- Mysql数据库内置功能之函数
一 函数 MySQL中提供了许多内置函数,例如: 一.数学函数 ROUND(x,y) 返回参数x的四舍五入的有y位小数的值 RAND() 返回0到1内的随机值,可以通过提供一个参数(种子)使RAND( ...
- Angular NgModule(模块)
NgModule 模块是Angular种一个重要的点,因为Angular的基本构造块就是NgModule.NgModule 会把相关的代码收集到一些功能集中,形成功能单元.在使用Angular CL ...
- 02hive数据类型
一. 基本数据类型 对于 Hive 的 String 类型相当于数据库的 varchar 类型,该类型是一个可变的字符串,不过它不能声明其中最多能存储多少个字符,理论上它可以存储 2GB 的字符数. ...
- 对DensePose: Dense Human Pose Estimation In The Wild的理解
研究方法 通过完全卷积学习从图像像素到密集模板网格的映射.将此任务作为一个回归问题,并利用手动注释的面部标注来训练我们的网络.使用这样的标注,在三维对象模板和输入图像之间,建立密集的对应领域,然后作为 ...
- socketserver模块(实现并发)
socketserver模块(实现并发) 一.基于UDP协议实现的并发 # 服务端 import socketserver class MyServer(socketserver.BaseReques ...
- C++中map的介绍用法以及Gym题目:Two Sequences
Map是STL的一个关联容器,它提供一对一(其中第一个可以称为关键字(key),每个关键字只能在map中出现一次,第二个可能称为该关键字的值(value))的数据 处理能力,由于这个特性,它完成有可能 ...
- Maven (一)--- 入门和依赖
部分图片来自参考资料 问题 : - maven 生命周期是怎么样的 - mvn clean install 与 mvn clean deploy 的区别是什么 概述 Maven 是一种构建项目的工具, ...