zTree【简单介绍】



zTree 是利用 JQuery 的核心代码,实现一套能完毕大部分经常使用功能的 Tree 插件

兼容 IE、FireFox、Chrome 等浏览器

在一个页面内可同一时候生成多个 Tree 实例

支持 JSON 数据

支持一次性静态生成 和 Ajax 异步载入 两种方式

支持多种事件响应及反馈

支持 Tree 的节点移动、编辑、删除

支持随意更换皮肤 / 个性化图标(依靠css)

支持极其灵活的 checkbox 或 radio 选择功能

简单的參数配置实现 灵活多变的功能







【官网】



官网地址:http://www.baby666.cn/hunter/index.html



在官网可下面载到zTree的源代码、实例和API,当中作者pdf的API写得很具体

【部分函数和属性介绍】

核心:zTree(setting, [zTreeNodes])



这个函数接受一个JSON格式的数据对象setting和一个JSON格式的数据对象zTreeNodes,从而建立 Tree。





核心參数:setting



zTree 的參数配置都在这里完毕,简单的说:树的样式、事件、訪问路径等都在这里配置

setting 举例:

var setting = {

showLine: true,

checkable: true

};

由于參数太多,详细參数详见zTreeAPI

核心參数:zTreeNodes

zTree 的所有节点数据集合,採用由JSON对象组成的数据结构,简单的说:这里使用Json格式保存了树的所有信息

zTreeNodes的格式分为两种:利用Json格式嵌套体现父子关系和Array简单格式

1 带有父子关系的标准 zTreeNodes 举例:

var zTreeNodes = [

{"id":1, "name":"test1", "nodes":[

{"id":11, "name":"test11", "nodes":[

{"id":111, "name":"test111"}

]},

{"id":12, "name":"test12"}

]},

......

];



2 带有父子关系的简单 Array 格式(isSimpleData)的 zTreeNodes 举例:



var treeNodes = [

{"id":1, "pId":0, "name":"test1"},

{"id":11, "pId":1, "name":"test11"},

{"id":12, "pId":1, "name":"test12"},

{"id":111, "pId":11, "name":"test111"},

......

];

【实例一】(Java代码)

1. 在页面引用zTree的js和css:

<!-- ZTree树形插件 -->

<link rel="stylesheet" href="<%=root%>/Web/common/css/zTreeStyle/zTreeStyle.css" type="text/css">

<!-- <link rel="stylesheet" href="<%=root%>/Web/common/css/zTreeStyle/zTreeIcons.css" type="text/css"> -->

<script type="text/javascript" src="<%=root%>/Web/common/js/jquery-ztree-2.5.min.js"></script>

2. 在script脚本中定义setting和zTreeNodes

var setting = {

isSimpleData : true, //数据是否採用简单 Array 格式,默认false

treeNodeKey : "id", //在isSimpleData格式下,当前节点id属性

treeNodeParentKey : "pId", //在isSimpleData格式下,当前节点的父节点id属性

showLine : true, //是否显示节点间的连线

checkable : true //每一个节点上是否显示 CheckBox

};

var treeNodes = [

{"id":1, "pId":0, "name":"test1"},

{"id":11, "pId":1, "name":"test11"},

{"id":12, "pId":1, "name":"test12"},

{"id":111, "pId":11, "name":"test111"},

];





3. 在进入页面时生成树结构:

var zTree;

$(function() {

zTree = $("#tree").zTree(setting, treeNodes);

});

4. 最后查看效果:





【实例二】(从后台获取简单格式Json数据)

1. 后台代码封装简单格式Json数据:

public void doGetPrivilegeTree() throws IOException{

String s1 = "{id:1, pId:0, name:\"test1\" , open:true}";

String s2 = "{id:2, pId:1, name:\"test2\" , open:true}";

String s3 = "{id:3, pId:1, name:\"test3\" , open:true}";

String s4 = "{id:4, pId:2, name:\"test4\" , open:true}";

List<String> lstTree = new ArrayList<String>();

lstTree.add(s1);

lstTree.add(s2);

lstTree.add(s3);

lstTree.add(s4);

//利用Json插件将Array转换成Json格式

response.getWriter().print(JSONArray.fromObject(lstTree).toString());

}

2. 页面使用Ajax获取zTreeNodes数据再生成树

var setting = {

isSimpleData : true, //数据是否採用简单 Array 格式,默认false

treeNodeKey : "id", //在isSimpleData格式下,当前节点id属性

treeNodeParentKey : "pId", //在isSimpleData格式下,当前节点的父节点id属性

showLine : true, //是否显示节点间的连线

checkable : true //每一个节点上是否显示 CheckBox

};

var zTree;

var treeNodes;

$(function(){

$.ajax({

async : false,

cache:false,

type: 'POST',

dataType : "json",

url: root+"/ospm/loginInfo/doGetPrivilegeTree.action",//请求的action路径

error: function () {//请求失败处理函数

alert('请求失败');

},

success:function(data){ //请求成功后处理函数。

alert(data);

treeNodes = data; //把后台封装好的简单Json格式赋给treeNodes

}

});

zTree = $("#tree").zTree(setting, treeNodes);

});

3. 最后显示效果

Jquery zTree实例的更多相关文章

  1. jQuery zTree v3.5 实例3 异步树

    最终效果: 点击非叶子节点时,向后台发送请求,获取下级菜单 前台代码如下: <%@ page language="java" contentType="text/h ...

  2. jquery Ztree v3.5 实例2 自定义显示在节点前的图片

    显示效果如下: 代码如下: <html> <head><title></title></head> <script type=&quo ...

  3. C#使用Jquery zTree实现树状结构显示_异步数据加载

    JQuery-Ztree下载地址:https://github.com/zTree/zTree_v3 JQuery-Ztree数结构演示页面:  http://www.treejs.cn/v3/dem ...

  4. JQuery ztree 异步加载实践

    本来要做一个文件目录浏览界面,需要遍历所有的文件和目录,很显然一次性读取时很费时费力的一件事情. 因此就需要做异步加载.... 不过网上的几篇帖子还挺坑的!原始参考:JQuery异步加载实例,相对来说 ...

  5. jQuery+zTree加载树形结构菜单

    jQuery+zTree加载树形结构菜单 由于项目中需要设计树形菜单功能,经过一番捣腾之后,终于给弄出来了,所以便记下来,也算是学习zTree的一个总结吧. zTree的介绍: 1.zTree 是利用 ...

  6. jQuery+zTree

    0 zTree简介 树形控件的使用是应用开发过程中必不可少的.zTree 是一个依靠 jQuery 实现的多功能 “树插件”.优异的性能.灵活的配置.多种功能的组合是 zTree 最大优点. 0.0 ...

  7. jQuery Ajax 实例 ($.ajax、$.post、$.get)

    jQuery Ajax 实例 ($.ajax.$.post.$.get) 转 Jquery在异步提交方面封装的很好,直接用AJAX非常麻烦,Jquery大大简化了我们的操作,不用考虑浏览器的诧异了. ...

  8. jQuery.zTree的跳坑记录

    最近项目用到树型结构的交互,一开始并不打算选择zTree,为了项目进度我妥协了,这一妥协后果就是我进坑了,在2天的挣扎中,我终于跳出坑了,活了下来,有一些感慨纪录下来. 有一个业务场景需要2个树型结构 ...

  9. JavaScript强化教程——jQuery AJAX 实例

    什么是 AJAX?AJAX = 异步 JavaScript 和 XML(Asynchronous JavaScript and XML).简短地说,在不重载整个网页的情况下,AJAX 通过后台加载数据 ...

随机推荐

  1. 玩转Web之easyui(一)-----easy ui datagird 分页

    easy ui 中数据表格的分页其实是很简单的,分页是在数据表格可以正常显示数据的基础上进行的,在这里给出servlet的代码,其中selectAll()方法是从数据库中提取所有数据, 分页的一种思路 ...

  2. ubuntu快捷键设置,查看系统

    设置system setting于.点击键盘keyboard,有捷径keyboard shortcut.但也设置快捷键本身. 版权声明:本文博主原创文章,博客,未经同意不得转载.

  3. 读书时间《JavaScript高级程序设计》四:BOM,客户端检测

    隔了一段时间,现在开始看第8章. 第8章:BOM BOM提供了很多对象,用于访问浏览器的功能.BOM的核心对象是window,它表示浏览器的一个实例. window对象是通过javascript访问浏 ...

  4. RedHat Linux乱码解决方案(转)

    RedHat Linux中出现中文乱码主要是由于没有安装中文字体,因此解决方案主要是安装中文字体,所以 第一步,挂载安装的光盘 在虚拟机的菜单栏里,选择:VM->Settings,点击Setti ...

  5. ASP.NET分页正品—分页真

     承接上篇博文<ASP.NET真假分页-假分页>:http://blog.csdn.net/u010773667/article/details/38845009,继续解说ASP.NE ...

  6. Objective-C开发编码规范

    Objective-C 编码规范,内容来自苹果.谷歌的文档翻译,自己的编码经验和对其它资料的总结. 概要 Objective-C 是一门面向对象的动态编程语言,主要用于编写 iOS 和 Mac 应用程 ...

  7. 存储数据键和项目对的类(Dictionary对象)

    存储数据键和项目对的类(Dictionary对象) <% Class Dictionary Public Copyright, Developer, Name, Version, Web Pri ...

  8. C++四种类型的转换

    在C/C++使用的语言 (type) value(您还可以使用type(value))对于显式类型转换,经常提到投.转换程序猿的精度等完全掌握手,一个传统投往往是过度使用.成为C++要根源. 为了降低 ...

  9. fastclick 源码阅读备份

    ;(function () { 'use strict'; //构造函数 function FastClick(layer, options) { var oldOnClick; options = ...

  10. Visual Studio Team Services使用教程--默认团队权限说明