首页 > 代码库 > 用JavaScript实现一个简单的树结构
用JavaScript实现一个简单的树结构
数据源用数组混json结构,实现了基本的功能。效率一般,跟 dhtree 梅花雪树对比了下,都差不多。 (ps感觉比dhtree快点,跟梅花雪树差不多,个人测试)
这个实现树的原理是根据json,不断的生成ul li, 下面是一个简单的例子(只有涉及到生成树,也就是说只是展示,tree类代码只有64行) 没有用innerHTML生成,全是是创建节点来创建ul li,所以创建节点碎片添加,然后再一次性添加很重要啊,确实能提高速度。泌阳县马奇建材
上面只是一个简单的树,但是树应该是有input的,并且能够选中。记录选中能够开打任何节点,能够删除,不能够编辑、保存。说一下我在这里怎么完成上面的功能。选中应该是比较麻烦的,因为选中了一个节点,要让他所有的子节点都选中,他的父节点也有可能要选中(如果同级的都是选中状态的)。接着他的父的父也有可能要选中,所以设计到很多的查找,当生成一个li的时候,给li一个属性:
view source print?
1 | li.child.push({ |
2 | li : li, |
3 | input : isInput ?$q( ‘input‘ ,li)[0]:undefined, |
4 | data : o |
5 | }); |
记录下他下一级(是下一级 不是所有的子 )的所有的input 和li同时记录父的li 和 input:
view source print?
1 | li.parent = { |
2 | li : parent, |
3 | input : isInput ?$q( ‘input‘ ,parent)[0]:undefined |
4 | }; |
这样查找起来很方便,但是内存就要用的多些了。
基本能达到要求了。
用JavaScript实现一个简单的树结构
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。