【学习 jQuery EasyUI 】 jQuery EasyUI 教程 jQuery EasyUI 简介 jEasyUI 应用 jEasyUI 创建 CRUD 应用 jEasyUI 创建 CRUD 数据网格 jEasyUI 表单的 CRUD 应用 jEasyUI 创建 RSS 阅读器 jEasyUI 拖放 jEasyUI 基本的拖动和放置 jEasyUI 创建拖放的购物车 jEasyUI 创建学校课程表 jEasyUI 菜单与按钮 jEasyUI 创建简单的菜单 jEasyUI 创建链接按钮 jEasyUI 创建菜单按钮 jEasyUI 创建分割按钮 jEasyUI 布局 jEasyUI 创建边框布局 jEasyUI 创建复杂布局 jEasyUI 创建折叠面板 jEasyUI 创建标签页 jEasyUI 动态添加标签页 jEasyUI 添加自动播放标签页 jEasyUI 创建 XP 风格左侧面板 jEasyUI 数据网格 jEasyUI 转换 HTML 表格为数据网格 jEasyUI 取得选中行数据 jEasyUI 添加查询功能 jEasyUI 添加工具栏 jEasyUI 创建复杂工具栏 jEasyUI 设置冻结列 jEasyUI 动态改变列 jEasyUI 格式化列 jEasyUI 设置排序 jEasyUI 自定义排序 jEasyUI 创建列组合 jEasyUI 添加复选框 jEasyUI 自定义分页 jEasyUI 启用行内编辑 jEasyUI 扩展编辑器 jEasyUI 列运算 jEasyUI 合并单元格 jEasyUI 创建自定义视图 jEasyUI 创建页脚摘要 jEasyUI 条件设置行背景颜色 jEasyUI 创建属性网格 jEasyUI 扩展行显示细节 jEasyUI 创建子网格 jEasyUI 显示海量数据 jEasyUI 添加分页组件 jEasyUI 窗口 jEasyUI 创建简单窗口 jEasyUI 自定义窗口工具栏 jEasyUI 窗口与布局 jEasyUI 创建对话框 jEasyUI 自定义对话框 jEasyUI 树形菜单 jEasyUI 使用标记创建树形菜单 jEasyUI 创建异步树形菜单 jEasyUI 树形菜单添加节点 jEasyUI 创建带复选框的树形菜单 jEasyUI 树形菜单拖放控制 jEasyUI 树形菜单加载父/子节点 jEasyUI 创建基础树形网格 jEasyUI 创建复杂树形网格 jEasyUI 树形网格动态加载 jEasyUI 树形网格添加分页 jEasyUI 树形网格惰性加载节点 jEasyUI 表单 jEasyUI 创建异步提交表单 jEasyUI 表单验证 jEasyUI 创建树形下拉框 jEasyUI 格式化下拉框 jEasyUI 过滤下拉数据网格 jEasyUI 参考手册 jQuery EasyUI 插件 jQuery EasyUI 扩展

jEasyUI 树形网格惰性加载节点学习笔记

什么是惰性加载?

惰性加载也叫延迟加载,指的是在需要的时候才加载数据,而不是一次性加载所有数据。这样可以减轻服务端负担,提高页面渲染速度。

如何实现树形网格的惰性加载?

jEasyUI 是一款常用的 UI 框架,在其树形网格组件中提供了惰性加载节点的功能。实现方法如下:

  1. 在树形结构的节点属性中设置 state 属性为 closed,表示该节点默认处于关闭状态,不加载子节点。
  2. 在设置树形网格的 loadFilter 属性中,编写回调函数,该函数可以根据需要对数据进行处理,过滤出需要显示的节点数据。
  3. onClick 事件中,通过调用 treegridreload 方法,动态加载当前节点的子节点数据。

具体实现代码如下所示:

htmlCopy Code
<div id="treegrid"></div>
javascriptCopy Code
$('#treegrid').treegrid({ url: 'data.json', idField: 'id', treeField: 'name', loadFilter: function(data, parentId) { // 过滤出需要显示的节点数据 var nodes = []; for (var i=0; i<data.length; i++) { var node = data[i]; if (node.parentId == parentId) { nodes.push(node); } } return nodes; }, onClick: function(row) { var node = $('#treegrid').treegrid('find', row.id); if (node.state == 'closed') { // 加载子节点数据 $('#treegrid').treegrid('reload', row.id); // 更新节点状态为打开状态 $('#treegrid').treegrid('expand', row.id); } else { // 更新节点状态为关闭状态 $('#treegrid').treegrid('collapse', row.id); } } });

实例演示

下面是一个简单的 demo,演示了 jEasyUI 树形网格惰性加载节点的效果。点击父节点时,会动态加载子节点数据。

htmlCopy Code
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>jEasyUI 树形网格惰性加载节点学习笔记</title> <link rel="stylesheet" type="text/css" href="https://cdn.bootcss.com/jquery-easyui/1.9.22/themes/default/easyui.css"> <link rel="stylesheet" type="text/css" href="https://cdn.bootcss.com/jquery-easyui/1.9.22/themes/icon.css"> <script type="text/javascript" src="https://cdn.bootcss.com/jquery/1.12.4/jquery.min.js"></script> <script type="text/javascript" src="https://cdn.bootcss.com/jquery-easyui/1.9.22/jquery.easyui.min.js"></script> </head> <body> <div id="treegrid"></div> <script type="text/javascript"> $('#treegrid').treegrid({ url: 'data.json', idField: 'id', treeField: 'name', loadFilter: function(data, parentId) { // 过滤出需要显示的节点数据 var nodes = []; for (var i=0; i<data.length; i++) { var node = data[i]; if (node.parentId == parentId) { nodes.push(node); } } return nodes; }, onClick: function(row) { var node = $('#treegrid').treegrid('find', row.id); if (node.state == 'closed') { // 加载子节点数据 $('#treegrid').treegrid('reload', row.id); // 更新节点状态为打开状态 $('#treegrid').treegrid('expand', row.id); } else { // 更新节点状态为关闭状态 $('#treegrid').treegrid('collapse', row.id); } } }); </script> </body> </html>

data.json 文件内容如下:

jsonCopy Code
[ { "id": 1, "name": "node1", "parentId": 0, "state": "closed" }, { "id": 2, "name": "node2", "parentId": 0, "state": "closed" }, { "id": 3, "name": "node3", "parentId": 1, "state": "closed" }, { "id": 4, "name": "node4", "parentId": 1, "state": "closed" }, { "id": 5, "name": "node5", "parentId": 2, "state": "closed" }, { "id": 6, "name": "node6", "parentId": 2, "state": "closed" }, { "id": 7, "name": "node7", "parentId": 3 }, { "id": 8, "name": "node8", "parentId": 3 }, { "id": 9, "name": "node9", "parentId": 4 }, { "id": 10, "name": "node10", "parentId": 4 }, { "id": 11, "name": "node11", "parentId": 5 }, { "id": 12, "name": "node12", "parentId": 5 }, { "id": 13, "name": "node13", "parentId": 6 }, { "id": 14, "name": "node14", "parentId": 6 } ]

打开浏览器访问该页面,即可看到树形网格组件。点击父节点时,子节点数据会被动态加载。

总结

jEasyUI 树形网格惰性加载节点功能可以优化页面性能,降低服务端压力。使用简单,只需通过设置节点属性和编写回调函数即可实现。