急求easyui tree绑定子节点,数据量过多的问题!

老炮 2015-07-15 12:09:55
现在项目中有个模块用到easyui tree ,在点击一个父节点的时候要绑定数据库查询出来的数据,但是现在这个数据量有点多在大几千条以上。用easyui的 绑定方法
$('#Typelist').tree('append', {
parent: root.target, data: data,
});
一般的机器就卡死了。性能好的机器得等10秒。想请教下有没有什么优化的好方法。现在只有切割数据分多次绑定的想法。还有个是先绑定xx条。后面显示一个双向下箭头点击在绑定xx条(但是不知道怎么实现),希望有高手赐教一下!感激不尽
...全文
496 9 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
香蕉猪 2015-07-16
  • 打赏
  • 举报
回复
后台控制,,,第一次就取第一到第十,,,第二次取是一到二十,,,,以此类推。。。
老炮 2015-07-15
  • 打赏
  • 举报
回复
引用 1 楼 apollokk 的回复:
既然是树,肯定有多级的,异步加载就好了,第一次只加载第一层
第一次是加载一层,但是点击第一层加载第二层数据就很多了。就很卡
Hello World, 2015-07-15
  • 打赏
  • 举报
回复
既然是树,肯定有多级的,异步加载就好了,第一次只加载第一层
tony4geek 2015-07-15
  • 打赏
  • 举报
回复
一层层的加载,按需加载/
Hello World, 2015-07-15
  • 打赏
  • 举报
回复
你现在才二级,再加多二级,每级10个分类来算,数据量就减少到1%了(理想状态)
Hello World, 2015-07-15
  • 打赏
  • 举报
回复
引用 4 楼 u010527447 的回复:
[quote=引用 3 楼 apollokk 的回复:] 也不是一次加载所有第二层,只要加载点击的那个点下面的第二层;怎么会卡呢?
就是点击那个点下面需要加载的第二层数据很多啊。比如点击病例这个父节点。就把病例表下面所有的病例标题当做子节点加入到病例这个节点下[/quote] 这样加载确实会很多,可以从设计上考虑下,比如按年度再分一级,或者按其它属性再分级,不然时间长了几万几十万就更没法玩了
  • 打赏
  • 举报
回复
分好层次,异步加载,而不是一次性加载所有的数据,几千条也太多了点吧,
老炮 2015-07-15
  • 打赏
  • 举报
回复
引用 3 楼 apollokk 的回复:
也不是一次加载所有第二层,只要加载点击的那个点下面的第二层;怎么会卡呢?
就是点击那个点下面需要加载的第二层数据很多啊。比如点击病例这个父节点。就把病例表下面所有的病例标题当做子节点加入到病例这个节点下
Hello World, 2015-07-15
  • 打赏
  • 举报
回复
也不是一次加载所有第二层,只要加载点击的那个点下面的第二层;怎么会卡呢?
(题外话:从本次开始 我新增了jQuery EasyUI的专题页面 大家可以关注我的专题页来及时获取最新的EasyUI资源 专题页地址如下http:http://download.csdn.net/album/detail/343 同时也希望转载的那些朋友能保留我资源的说明及出处地址 我花那么多精力制作出来的 你们鼠标点两下就给我转走了还不注明出处 实在是不厚道 本来就是本着分享精神的 为的就是聚集一点人气和提供一个优良的环境来一起学习进步的 请不要抹杀掉我的热情 谢谢 )   时隔4个月之久 EasyUI终于迎来大版本更新了 本次更新内容诸多 除了常规维护外 还新增了3个新组件 都很实用 详细的可以阅读更新说明 里面给了详细的解读 另外 从该版本开始我将会逐步的将EasyUI官方以及第三方较好的插件API整合到API文档当中 并且会对这些插件做一些简单的Demo实现 存放到配套提供的程序包demo文件夹下 以便大家学习和使用 本期文档中将官方提供的所有附加插件的API都整理并存放到Extension节点下了 这些扩展的demo在附带的程序包中已经提供 可以用于参考使用 jQuery EasyUI 1 4版本更新内容: Bug(修复) menu:修复在删除一个菜单项的时候该菜单无法正确自适应高度的问题; datagrid:修复在datagrid宽度太小的时候“fitColumns”方法无法正常工作的问题 Improvement(改进) EasyUI的所有组件已经支持非固定 百分比大小的尺寸设置; menu:添加“showItem” “hideItem”和“resize”方法; menu:基于窗体大小自动调整高度; menu:添加“duration”属性 该属性允许用户自定义隐藏菜单动画的持续时间 以毫秒为单位; validatebox:添加“onBeforeValidate”和“onValidate”事件; combo:从该版本开始combo组件扩展自textbox组件(textbox是1 4中新增的组件); combo:添加“panelMinWidth” “panelMaxWidth” “panelMinHeight”和“panelMaxHeight”属性; searchbox:从该版本开始searchbox组件扩展自textbox组件(textbox是1 4中新增的组件); tree:添加“getRoot”方法 用于返回通过“nodeEl”参数指定的节点的顶部父节点元素 注意:官网的英文API中该函数的说明有误 其说明是none 无参数 实际这里是需要参数的 ; tree:添加“queryParams”属性; datetimebox:添加“spinnerWidth”属性; panel:添加“doLayout”方法 用于控制面板内组件的大小; panel:添加“clear”方法 用于清除面板内的内容; datagrid:允许用户设置百分比宽度的列(该功能真是千呼万唤始出来啊 ); form:添加“ajax” “novalidate”和“queryParams”属性; linkbutton:添加“resize”方法 New Plugin(新组件) textbox:该组件是一个增强的输入字段 它可以让用户非常简单的构建一个表单; datetimespinner:该组件是一个日期和时间的微调组件 它允许我们选择一个特定的日期或时间; filebox:filebox 该组件表单元素中用于上传文件的文件框工具组件 ">(题外话:从本次开始 我新增了jQuery EasyUI的专题页面 大家可以关注我的专题页来及时获取

87,997

社区成员

发帖
与我相关
我的任务
社区描述
Web 开发 JavaScript
社区管理员
  • JavaScript
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧