码迷,mamicode.com
首页 > 编程语言 > 详细

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

时间:2014-10-23 09:29:23      阅读:286      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   color   io   os   ar   java   for   

数据源用数组混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     };

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


基本能达到要求了。

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

标签:style   blog   http   color   io   os   ar   java   for   

原文地址:http://www.cnblogs.com/xiaoyang002/p/4044926.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!