1、首先去官网下载http://www.ztree.me/v3/main.php#_zTreeInfo
2、之后引入:
<script src="js/jquery.ztree.all-3.5.js">script>
"css/zTreeStyle/zTreeStyle.css" rel="stylesheet" type="text/css">
3、写js:
文本框的代码:
type="text" class="form-control input-sm" id="treeName" onclick="showMenu()">
type="hidden" name="newsTypeId" id="treeId"/>
树状图显示的地方:
<div id="treeContainer" class="treeContainer">
id="treeConfig" class="ztree">
div>
必要的样式:
.treeContainer{
display:none;
position: absolute;
}
以下是详解:
数据填充
重点就在于zNodes的配置。就是要配置好id、pId、name;这三个属性。
var zNodes =[
<#if selectNewsTypeAll?size gt 0>
<#list selectNewsTypeAll as sNewsTypeAll>
{
id:${sNewsTypeAll.id},
pId:${sNewsTypeAll.parentId},
name:"${sNewsTypeAll.name}"
},
#list>
#if>
];
setting 中callback是回调函数,我上面写了两个
callback: {
//节点点击事件
onClick: onClick,
//节点选中事件
onCheck: onCheck,
}
setting中其他属性默认,就行。
由于一加载页面就要把树状图准备好,只不过没有显示出来而已!所以需要以下代码
$(document).ready(function() {
//初始化
$.fn.zTree.init($("#treeConfig"), setting, zNodes);
});
节点点击事件,没什么说的,这样配置就可以了:
function onClick(e,treeId,treeNode) {
var zTree = $.fn.zTree.getZTreeObj("treeConfig");
zTree.checkNode(treeNode, !treeNode.checked, null, true);
return false;
}
节点选择事件:
function onCheck(e,treeId,treeNode) {
var zTree = $.fn.zTree.getZTreeObj("treeConfig"),
nodes = zTree.getCheckedNodes(true);
var name = "", id = "";
for (var i = 0, l = nodes.length; i < l; i++) {
name = nodes[i].name;
newsTypeId = nodes[i].id;
}
$("#treeName").val(name);
$("#treeId").val(id);
}
其中:
$("#treeName").val(name);
$("#treeId").val(id);
是根据自己的业务来的,我是因为在选择节点之后,要把,你选择的名字显示出来,并且id要写入隐藏字段,以便保存到数据库。
树状图是在什么时候显示出来呢?我设置的是当点击文本框的时候显示出来
function showMenu() {
var dropdownObj = $("#treeName");
var dropdownOffset = $("#treeName").offset();
$("#treeContainer").css({
left: dropdownOffset.left + "px",
top: dropdownOffset.top + dropdownObj.outerHeight() + "px"
}).slideDown("fast");
$("body").bind("mousedown", onBodyDown);
//获取文本框的宽度
var w = $("#treeName").width();
//获取文本框的内填充
var p = $("#treeName").css("padding-left");
//设置树状图的宽度
$("#treeConfig").css("width",parseInt(w)+parseInt(p)*2);
}
其中:
$("body").bind("mousedown", onBodyDown);
是绑定了一个鼠标点击事件,当点击其他区域,会触发onBodyDown事件。
function onBodyDown(event) {
if (!(event.target.id == "chooseButton" || event.target.id == "treeName" || event.target.id == "treeContainer" || $(event.target).parents("#treeContainer").length > 0)) {
hideMenu();
//以下代码暂时没用到 start
var height = top.$("#mainFrame").contents().find("body").height();
if (height < 850) {
height = 850;
}
top.$("#mainFrame").height(height);
//以下代码暂时没用到 end
}
}
这里面又调用hideMenu()把树状图隐藏掉。
需要用到的文本框代码:
type="text" class="form-control input-sm" id="treeName" onclick="showMenu()">
type="hidden" name="newsTypeId" id="treeId"/>
而用于显示树状图的代码是: 这段代码不一定要和上面那段文本框代码放在一起。
<div id="treeContainer" class="treeContainer">
id="treeConfig" class="ztree">
div>
因为,这里面做了位置的偏移。
function showMenu() {
var dropdownObj = $("#treeName");
//获取偏移量
var dropdownOffset = $("#treeName").offset();
$("#treeContainer").css({
left: dropdownOffset.left + "px",
top: dropdownOffset.top + dropdownObj.outerHeight() + "px"
}).slideDown("fast");
$("body").bind("mousedown", onBodyDown);
var w = $("#treeName").width();
var p = $("#treeName").css("padding-left");
$("#treeConfig").css("width",parseInt(w)+parseInt(p)*2);
}
由于zTree自带的样式不好看,我进行了细微的跳转,只是让显示稍微好看些
/*一定要的*/
.treeContainer{
display:none;
position: absolute;
}
/*根据自己情况而定*/
.treeContainer .ztree{
background-color:#FFF;
}