news 2026/2/1 23:16:31

jQuery EasyUI 树形菜单 - 树形网格动态加载

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
jQuery EasyUI 树形菜单 - 树形网格动态加载

jQuery EasyUI 树形网格(TreeGrid) - 动态加载(按需加载子节点)

jQuery EasyUI TreeGrid 支持两种常见的“动态加载”方式:

  1. 服务器端按需加载(On-Demand Loading / Remote Lazy Loading)
    最常见场景:首次加载根节点,展开节点时向服务器请求该节点的子节点数据(推荐用于大数据量)。

  2. 客户端懒加载(Client Lazy Loading)
    一次性从服务器获取全部层级数据,但首次只显示根节点,展开时在客户端逐步追加子节点(适用于已知全部数据但想避免一次性渲染过多节点)。

下面分别提供完整示例。

示例1:服务器端按需动态加载(推荐)

TreeGrid 会自动在展开节点时向服务器发送参数id(父节点ID),服务器根据id返回子节点数组。

HTML 部分

<!DOCTYPEhtml><html><head><metacharset="UTF-8"><title>TreeGrid 服务器端动态加载</title><linkrel="stylesheet"type="text/css"href="https://www.jeasyui.com/easyui/themes/default/easyui.css"><linkrel="stylesheet"type="text/css"href="https://www.jeasyui.com/easyui/themes/icon.css"><scripttype="text/javascript"src="https://code.jquery.com/jquery-1.12.4.min.js"></script><scripttype="text/javascript"src="https://www.jeasyui.com/easyui/jquery.easyui.min.js"></script></head><body><h2>TreeGrid - 服务器端按需加载子节点</h2><tableid="tg"class="easyui-treegrid"style="width:700px;height:500px"data-options="url:'treegrid_dynamic.php', <!-- 服务器脚本 --> method:'get', rownumbers: true, idField:'id', treeField:'name', lines: true"><thead><tr><thfield="name"width="300">名称</th><thfield="size"width="100"align="right">大小</th><thfield="date"width="150">修改日期</th></tr></thead></table></body></html>

服务器端示例(treegrid_dynamic.php)

<?php// 获取父节点ID(首次加载根节点时 id 为 null 或不存在)$parentId=isset($_GET['id'])?$_GET['id']:null;// 模拟数据(实际从数据库查询)$data=array();if($parentId==null){// 根节点$data[]=array('id'=>1,'name'=>'Applications','size'=>'','date'=>'2025-01-01','state'=>'closed');$data[]=array('id'=>2,'name'=>'Documents','size'=>'','date'=>'2025-02-01','state'=>'closed');}elseif($parentId==1){// Applications 的子节点$data[]=array('id'=>11,'name'=>'EasyUI','size'=>'2MB','date'=>'2025-12-01');$data[]=array('id'=>12,'name'=>'jQuery','size'=>'1MB','date'=>'2025-11-01');}elseif($parentId==2){// Documents 的子节点$data[]=array('id'=>21,'name'=>'Report.pdf','size'=>'500KB','date'=>'2025-12-10');}echojson_encode($data);?>

关键点

  • 有子节点的父节点需设置"state": "closed",这样才会显示展开图标。
  • 首次请求无id参数,返回根节点。
  • 展开时自动带id参数请求子节点。
示例2:客户端懒加载(一次性加载全部数据,但逐步渲染)

适用于已获取完整层级数据,但想避免一次性渲染大量节点。

HTML 部分

<tableid="tg"class="easyui-treegrid"title="客户端懒加载 TreeGrid"style="width:700px;height:500px"data-options="url:'treegrid_full_data.json', method:'get', rownumbers: true, idField:'id', treeField:'name', lines: true, loadFilter: myLoadFilter"><thead><tr><thfield="name"width="300">名称</th><thfield="size"width="100"align="right">大小</th><thfield="date"width="150">修改日期</th></tr></thead></table><scripttype="text/javascript">functionmyLoadFilter(data,parentId){functionsetData(){vartodo=[];for(vari=0;i<data.length;i++){todo.push(data[i]);}while(todo.length){varnode=todo.shift();if(node.children){node.state='closed';// 有子节点时关闭node.children1=node.children;// 临时保存子节点node.children=undefined;// 清空,避免立即加载todo=todo.concat(node.children1);}}}setData(data);varopts=$(this).treegrid('options');opts.onBeforeExpand=function(row){if(row.children1){$(this).treegrid('append',{parent:row[opts.idField],data:row.children1});row.children1=undefined;$(this).treegrid('expand',row[opts.idField]);}returnrow.children1==undefined;// 已加载则不再触发};returndata;}</script>

treegrid_full_data.json(完整层级数据示例,与基础示例相同)

官方参考
  • 服务器端动态加载:https://www.jeasyui.com/tutorial/tree/treegrid3.php
  • 客户端懒加载:https://www.jeasyui.com/tutorial/tree/treegrid5.php
  • Demo 页面:https://www.jeasyui.com/demo/main/index.php?plugin=TreeGrid (查看 Dynamic Loading 和 Lazy Loading 示例)

如果需要结合分页、编辑或其他功能,或提供你的后端语言(PHP/Java/Node 等),我可以给出更具体的服务器端代码!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/30 4:32:13

jQuery EasyUI 树形菜单 - 树形网格添加分页

jQuery EasyUI 树形网格&#xff08;TreeGrid&#xff09; - 添加分页 jQuery EasyUI 的 TreeGrid 继承自 DataGrid&#xff0c;因此支持 pagination: true 属性来启用分页功能。但由于 TreeGrid 是层级结构&#xff0c;分页通常只针对顶级根节点进行&#xff08;子节点通过动…

作者头像 李华
网站建设 2026/1/31 7:26:03

Kotaemon如何应对文化差异?本地化适配策略分析

Kotaemon如何应对文化差异&#xff1f;本地化适配策略分析 在智能客服系统走向全球的今天&#xff0c;一个看似简单的用户提问——“我能不能退货&#xff1f;”——背后可能隐藏着巨大的文化鸿沟。在日本&#xff0c;这或许是一句含蓄的情绪表达&#xff1b;在德国&#xff0c…

作者头像 李华
网站建设 2026/1/29 20:32:45

IM即时通讯系统:安全可控、功能全面的社交解决方案全解析

在数字化社交时代&#xff0c;即时通讯&#xff08;IM&#xff09;系统已成为社交平台的核心基础设施。本文将深入解析开源IM系统的核心优势与功能亮点&#xff0c;为开发者提供一套安全可控、功能全面的社交解决方案。一、核心优势&#xff1a;安全与性能的双重保障1. 独立数据…

作者头像 李华
网站建设 2026/2/1 0:50:19

扭蛋机小程序开发制作!

扭蛋机便是盲盒的另一种形式&#xff0c;目前国内消费市场主要集中在互联网上&#xff0c;玩家在手机上就可以体验抽盲盒的乐趣&#xff0c;因此线上盲盒扭蛋机小程序的出现也是顺应市场发展。扭蛋机里面的盲盒商品一般是手办等&#xff0c;盲盒种类繁多&#xff0c;玩家可以抽…

作者头像 李华
网站建设 2026/1/30 4:57:29

英文论文写作工具推荐:8大AI+翻译润色排名+

英文论文写作工具推荐&#xff1a;8大AI翻译润色排名 &#xfffd;&#xfffd; 8款英文论文AI写作工具核心对比 工具名称 核心功能 处理速度 适合场景 独特优势 aibiye 降AIGC率查重 20分钟 学术论文优化 适配知网/维普检测规则 aicheck AIGC检测降重 20分钟 AI…

作者头像 李华
网站建设 2026/1/30 15:15:31

免费论文生成工具排名:8大网站+无水印下载推荐

免费论文生成工具排名&#xff1a;8大网站无水印下载推荐 核心工具对比速览 工具名称 核心功能 处理速度 适用场景 特色优势 aibiye AI论文生成降重 15-30分钟 初稿快速生成 学术术语精准匹配 aicheck AIGC检测降AI率 20分钟 论文合规性优化 知网/维普规则适配 …

作者头像 李华