架构师_程序员_码农网

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 4081|回复: 0

[JavaScript] JS--插件: 树Tree 开发与实现 附件可下载!!

[复制链接]
发表于 2019-7-11 11:20:12 | 显示全部楼层 |阅读模式
本帖最后由 szxiaxiaojun 于 2019-7-11 11:20 编辑

日常在Web项目开发时,经常会碰到树形架构数据的显示,从数据库中获取数据,并且显示成树形。为了方便,我们可以写一个javascript的一个跨浏览器树控件,后续可以重复使用。本节分享一个自己开发的JS tree插件,对有需要的朋友可以直接下载使用。
   Tree插件 需要实现
       (1)、自动将数据组织成上下级关系,这样我们在前端手工添加数据或者从数据库中获取到的数据不需要我们来组织上下级关系
       (2)、支持自定 加载目录树  支持XML、JSON 格式的数据加载
       (3)、实现树节点的选择(单选、复选[级联选择])功能
       (4)、支持大数据的一次性加载
       。。。。。。
   下面开始分享自己写的一个Tree 插件:  此插件基于Jquery  需要引用

    第一:插件中每个树节点Node的参数JSON对象如下所示
            nodeItem: function () {
                return {
                    nodecode: "",             //  节点编码
                    nodetext: "",               //  节点文本 [节点显示文本]
                    nodetitle: "",               //  节点标题 [用于鼠标移过时显示的节点文本]
                    supnodecode: "",       //  上级节点编码 [定义此节点所属的上级节点编码,通过此编码来组成上下级关系]
                    nodeurl: "",                 //  节点URL 表示当前节点自定的链接URL地址
                    iconexpand: "",           //  节点展开图标 [目录树节点自定展开状态下显示的图标,如果为空,则采用默认的图标]
                    iconcollapse: ""          //  节点收缩图标 [目录树节点自定收缩状态下显示的图标,如果为空,则采用默认的图标]
                }
            }
     第二:加载目录树的三种方法
             1、loadJson(Json)             JSON 对象目录树节点数组(一次性完成)
                                                       JSON 格式 是一个Array 数组  每项为一个 nodeItem 对象的参数
                                                       [
                                                            {   nodecode: "", nodetext: "", nodetitle: "",supnodecode: "",nodeurl: "",iconexpand: "" ,iconcollapse: "" },
                                                            {},...
                                                       ]

             2、loadXml(xml)                 XML字符串格式的节点数据(一次性完成)
                                                        说明:采用XML字符串格式  注意节点 tagName:nodecode nodetext 等 不允许变更 因为程序内部是直接采用这个名字来获取的         
                                                       <root>
                                                             <item>   //  每一个节点 内包含多个数据值   
                                                                  <nodecode><![CDATA[节点编码值]]></nodecode>     
                                                                  <nodetext><![CDATA[节点名称文本 ]]></nodetext>
                                                                  <nodetitle><![CDATA[节点鼠标移入显示提示文本]]></nodetitle>
                                                                  <supnodecode><![CDATA[节点所属上级即父节点编码]]></supnodecode>
                                                                  <nodeurl><![CDATA[节点关联链接地址]]></nodeurl>
                                                                  <iconexpand><![CDATA[节点展开时显示图标路径]]></iconexpand>   
                                                                  <iconcollapse><![CDATA[节点收缩时显示图标路径]]></iconcollapse>   
                                                            </item>
                                                            ... ...
                                                        </root>

             3、通过插件对象 的方法   addNodeItem(nodeItem)      通过手工一条一条的添加节点项目(需要两步完成) 全部添加完成后
                                                      通过插件对象 makeTree()    再手工调用此方法,则可以创建树

      第三:目录树内部重组上下级关系的事件方法  通过此方法,可以解决我们前端不再需要按照上下级关系来区分。
第四:以上只是简单的介绍了一下Tree的主要加载和重组方法。下面我们将完整的JS插件代码贴出来,代码中有详细的注释
                  插件功能:复选、单选、展开、折叠、显示/隐藏节点连线 、支持插入节点、删除节点、节点小图标自定义、设置节点选中、获取目录树选择节点(支持XML,JSON等)
                                  右击菜单(暂时不支持,因为需要用到弹出层,这里就屏蔽删除了此功能)  支持节点单击、双击、节点选择改变事件等等
最终显示效果
2222_20190711105313.png
附件下载:
Tree_Demo.rar (54.71 KB, 下载次数: 1)




上一篇:从Hadoop HDFS中直接下载文件
下一篇:Git 忽略提交 .gitignore
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

免责声明:
码农网所发布的一切软件、编程资料或者文章仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。如有侵权请邮件与我们联系处理。

Mail To:help@itsvse.com

QQ|手机版|小黑屋|架构师 ( 鲁ICP备14021824号-2 )|网站地图

GMT+8, 2024-4-19 16:09

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表