用JavaScript实现一个简单的树结构

数据源用数组混json结构,实现了基本的功能。效率一般,跟 dhtree 梅花雪树对比了下,都差不多。 (ps感觉比dhtree快点,跟梅花雪树差不多,个人测试)

这个实现树的原理是根据json,不断的生成ul li, 下面是一个简单的例子(只有涉及到生成树,也就是说只是展示,tree类代码只有64行) 没有用innerHTML生成,全是是创建节点来创建ul li,所以创建节点碎片添加,然后再一次性添加很重要啊,确实能提高速度。

上面只是一个简单的树,但是树应该是有input的,并且能够选中。记录选中能够开打任何节点,能够删除,不能够编辑、保存。说一下我在这里怎么完成上面的功能。选中应该是比较麻烦的,因为选中了一个节点,要让他所有的子节点都选中,他的父节点也有可能要选中(如果同级的都是选中状态的)。接着他的父的父也有可能要选中,所以设计到很多的查找,当生成一个li的时候,给li一个属性:

1 li.child.push({
2         li    : li,
3         input : isInput ?$q('input',li)[0]:undefined,
4         data  : o
5     });

记录下他下一级(是下一级 不是所有的子 )的所有的input 和li同时记录父的li 和 input:

1 li.parent = {
2         li    : parent,
3         input : isInput ?$q('input',parent)[0]:undefined
4     };

这样查找起来很方便,但是内存就要用的多些了。


基本能达到要求了。