注:本地预览请使用火狐浏览器,因调用外部xml数据chrome本地预览有跨域问题
主要特性
多浏览器/多平台支持
全部由JavaScript控制
动态加载
XML支持
大数据树动态翻译(智能XML解析)
拖拽(同一个树,不同的树之间,不同的框架之间)
带多选框(CheckBox)的树(两态/三态)
定制图标(使用JavaScript或xml)
内容菜单(与dhtmlxMenu集成)
结点数据为用户数据
多行结点
高稳定性
支持Macromedia Cold Fusion
支持Jsp
支持ASP.NET
支持以下浏览器
IE 5.5或更高版本
Mac OS X Safari
Mozilla 1.4 或更高版本
FireFox 0.9 或更高版本
Opera (Xml加载支持取决于浏览器版本)
dhtmlXTree是一款树形组件,其功能特别强大,基本上能满足大部分常规需求,也比较好用。下面是我整理的一些里面常用函数的说明,希望对大家有帮助
1 2 3 4 5 6 7 8 | dhtmlxcommon.jsdhtmlxtree.js基本生成需要引入css文件dhtmlxtree.css修改节点需要引入js文件dhtmlxtree_ed.js加载大数据XML需要引入JS文件:dhtmlxtree_srnd.js |
1 2 3 4 5 6 | 方法名: dhtmlXTreeObject(htmlObject,width,height,rootId)htmlObject:树生成窗口标识width:宽度height:深度rootId:根节点ID例: var tree=new dhtmlXTreeObject("tree","100%","100%",0); |
1 2 | 方法:setImagePath(Path);path:图片集的相对地址或绝对地址 |
1 2 3 4 5 6 7 8 9 10 11 | 方法名: insertNewChild(parentId,itemId,itemText,itemActionHandler,image1,image2,image3,optionStr,children)parentId: 需要插入位置的父节点IDitemId:自身IDitemText:节点显示名称itemActionHandler:节点事件(事件在XML配置)image1:节点自身图标 image2:展开/打开节点图标image3:收起节点图标children:子节点标志,可填节点对应的url |
1 2 3 4 5 6 7 8 9 10 11 | 方法名:insertNewNext(itemId,newItemId,itemText,itemActionHandler,image1,image2,image3,optionStr,children)itemId:需要追加节点的IDnewItemId:自身IDitemText: 节点显示名称image1: 节点自身图标image2: 展开/打开节点图标image3: 收起节点图标children: 子节点标志, 可填节点对应的url追加与添加不一样,添加节点只对需要父节点ID,而追加是需要前一个节点的ID |
1 2 3 | 方法名:deleteItem(itemId, selectParent);参数itemId: 删除节点ID,根据节点ID对节点删除;参数selectParent:删除后是否焦点在父节点, true/焦点在父节点 false/无焦点 |
1 2 | 方法名: enableDragAndDropScrolling(mode)参数mode: 是否可对节点进行拖拽 true/可以拖拽 false/不可拖拽 |
1 2 3 | 方法名:enableItemEditor(mode)mode: 是否可对节点进行修改 true/可以修改 false/不可修改注意: 这里要导入dhtmlxtree_ed.js文件 |
1 2 3 4 5 6 | 方法名:getSelectedItemId() 通过节点名查找节点并且该节点获取焦点方法名:findItem(searchStr,direction,top)参数searchStr:节点名(xml中Item的text属性)参数direction:设置查找方式0/从顶部(root)开始向下 1/从底部向上参数top:0/不从顶部开始查找 1/从顶部开始查找 |
1 2 3 | 方法名:loadXML(file,afterCall)file:读取树信息文件地址(可以是本地XML,JS数组,Json对象)afterCall:显示树后调用方法 |
1 2 3 4 5 | 方法名:setXMLAutoLoading(filePath)filePath: 自动读取加载节点信息地址(可以是本地XML,JS数组,Json对象)设置之后会自动对后台数据进行加载根据xml里面 Item 必须具有child属性如果不设置child属性将无法自动加载子节点 child属性可以设为0/无子节点 1/有子节点当打开节点时会自动将当前节点ID传入后台进行再次访问 |
1 2 3 4 5 6 7 8 9 10 11 | 一级节点<?xml version="1.0" encoding="utf-8" ?><tree id=”0”><item text="root" id="1" im0="book.gif" … child=”1”/></tree>二级节点:<?xml version="1.0" encoding="utf-8" ?><tree id=”1”><item text="node1" id="2" child=”1”/><item .../></tree> |
除了用xml可以进行对数据格式化外,还可以利用js,json对象将数据从后台传入页面,js和json基本都是利用多维数组的形式将数据传入页面
在XML中
tree标签是定义树的root节点ID
只有id属性
Item标签被包含于tree标签用于定义节点属性,可设置 多个属性包括
id ? 节点ID ,
text?节点名 ,
open ? 在载入时是否显示打开
select ? 在载入时是否被选中
child ? 是否具有子节点(动态加载时必须有此属性)
im0 ? ?有子节点的图示
im1 ? 关闭节点图示
im2 ? 开启节点图示
1 2 3 4 5 6 7 8 9 10 11 12 13 | <script>Var tree=new dhtmlXTreeObject("treeboxbox_tree","100%","100%",0);tree.setImagePath("codebase/imgs/");tree.enableDragAndDrop(false);tree.enableTreeLines(false); tree.setImageArrays("plus","","","","./csh_bluebooks/plus.gif");//设置通用展开图示:tree.setImageArrays("minus","","","","./csh_bluebooks/minus.gif");//通用收起图示: tree.setStdImages("./csh_bluebooks/book.gif", "./csh_bluebooks/folderOpen.gif","./csh_bluebooks/folderClosed.gif"); tree.loadXML("<%=url%>tree4.xml");</script> |
1 2 3 4 5 6 7 8 9 10 11 12 13 | <?xml version='1.0' encoding='utf-8'?><tree id="0"> <item text="Books" id="books"> <item text="Mystery & Thrillers" id="mystery" > <item text="Lawrence Block" id="lb" > <item text="The Burglar Who Thought He Was Bogart" id="lb_5" /> </item> <item text="Robert Crais" id="rc" > <item text="Hostage" id="rc_5" /> </item> </item> </item></tree> |
特别申明:
本站所有资源都是由网友投稿发布,或转载各大下载站,请自行检测软件的完整性!
本站所有资源仅供学习与参考,请勿用于商业用途,否则产生的一切后果将由您自己承担!
如有侵权请联系我们删除下架,联系方式:lei1294551502@163.com