对于easyUI实现一个树形表格,是一件很简单的事情,实现形式很多。
这里作者将实现,通过数据库获取数据,再将数据通过递归形式装成无限层级json数据,到达无限成级的树形表格结构。
需要用到的json插件建附件,希望能对大家有所帮助
效果如图
实现步逐
1、数据表设计(角色表)
CREATE TABLE `role` ( `id` varchar(32) NOT NULL, `createDate` datetime NOT NULL, `modifyDate` datetime NOT NULL, `name` varchar(64) NOT NULL, `isSystem` bit(1) NOT NULL, `description` varchar(256) NOT NULL, `fatherId` varchar(32) default '0' COMMENT '父id', PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8
2、实体
/** * 实体类 - 角色 * */ public class Role extends BaseEntity { private static final long serialVersionUID = -6614052029623997372L; private String name; //角色名称 private Boolean isSystem; //是否为系统内置角色 private String description; //描述 private List<Admin> adminList; //管理员 private List<Resource> resourceList; //资源 private String fatherId; //父角色id-xiongmin private String fatherName; //父角色名称-xiongmin private String children; //子角色 private String checked; //节点是否被选中 public String getName() { return name; } public void setName(String name) { this.name = name; } public Boolean getIsSystem() { return isSystem; } public void setIsSystem(Boolean isSystem) { this.isSystem = isSystem; } public String getDescription() { return description; } public void setDescription(String description) { this.description = description; } public List<Admin> getAdminList() { return adminList; } public void setAdminList(List<Admin> adminList) { this.adminList = adminList; } public List<Resource> getResourceList() { return resourceList; } public void setResourceList(List<Resource> resourceList) { this.resourceList = resourceList; } public String getFatherId() { return fatherId; } public void setFatherId(String fatherId) { this.fatherId = fatherId; } public String getFatherName() { return fatherName; } public void setFatherName(String fatherName) { this.fatherName = fatherName; } public String getChildren() { return children; } public void setChildren(String children) { this.children = children; } public String getChecked() { return checked; } public void setChecked(String checked) { this.checked = checked; } }
3、将角色封装成无限层级的json数据形式的关键代码,前端js调用方法
//存放转换后数据的集合 List<Map<String,Object>> treeGridList =new ArrayList<Map<String,Object>>(); /** * 返回 treeGrid(树形表格)需要的json格式数据 */ public String backTreeGridTreeRole(){ //得到所有角色 List<Role> list = roleService.getRoleAll(); //调用方法实现角色树 createTreeGridTree(list,"0"); //将集合转换为json输出到页面 Gson gson = new Gson(); String json = gson.toJson(treeGridList); try { ServletActionContext.getResponse().getWriter().print(json); ServletActionContext.getResponse().getWriter().flush(); ServletActionContext.getResponse().getWriter().close(); }catch (IOException e) { e.printStackTrace(); } System.out.println(json); return null; } /** * 将角色封装成树开始 * @param list * @param fid 父id */ private void createTreeGridTree(List<Role> list, String fid) { for (int i = 0; i < list.size(); i++) { Map<String, Object> map = null; Role role = (Role) list.get(i); if (role.getFatherId().equals("0")) { map = new HashMap<String, Object>(); //这里无所谓怎么转都行,因为在页面easyUI插件treeGrid提供了数据转换的columns属性,具体看相关的js代码 map.put("id", list.get(i).getId()); //id map.put("name", list.get(i).getName()); //角色名 map.put("children", createTreeGridChildren(list, role.getId())); } if (map != null) treeGridList.add(map); } } /** * 递归设置role树 * @param list * @param fid * @return */ private List<Map<String, Object>> createTreeGridChildren(List<Role> list, String fid) { List<Map<String, Object>> childList = new ArrayList<Map<String, Object>>(); for (int j = 0; j < list.size(); j++) { Map<String, Object> map = null; Role treeChild = (Role) list.get(j); if (treeChild.getFatherId().equals(fid)) { map = new HashMap<String, Object>(); //这里无所谓怎么转都行,因为在页面easyUI插件treeGrid提供了数据转换的columns属性,具体看相关的js代码 map.put("id", list.get(j).getId()); map.put("name", list.get(j).getName()); map.put("children", createTreeGridChildren(list, treeChild.getId())); } if (map != null) childList.add(map); } return childList; }
jsp页面
<div id= "treeGrid" style="width:285px;"></div>
js代码
$(function(){ $('#treeGrid').treegrid({ url:'role!backTreeGridTreeRole.action', idField: 'id', treeField:'name', columns: [[ {title: '角色id', field: 'id', width: 280, hidden:true}, {title: '角色名称', field: 'name', width: 280} ]] }) });
相关推荐
- **组件丰富**:jQuery EasyUI 提供了诸如对话框(Dialog)、表格(Grid)、树形控件(Tree)、下拉选择框(ComboBox)、菜单(Menu)等多种常见的 UI 控件,满足开发各种复杂界面的需求。 - **响应式设计**:...
EasyUI 的核心在于它的组件库,这些组件涵盖了网页设计中的常见需求,如表格(datagrid)、表单(form)、对话框(dialog)、菜单(menu)、树形结构(tree)、下拉选择框(combobox)等。通过这些组件,开发者可以...
3. **TreeGrid(树形表格)**: TreeGrid 是一个同时具备表格展示和树形结构的组件,它能够展示具有层级关系的数据,并支持分页、排序、筛选等功能。每个节点可以展开显示其子节点,同样采用异步加载方式,只在需要...
JeasyUI是一个基于jQuery的UI库,它提供了一系列简洁、易用的用户界面组件,包括表格、对话框、窗口、菜单、按钮等。...通过理解和掌握这些,你将能够创建出功能丰富的树形表格,有效地展示和管理层次结构的数据。
6. **树形组件**:`tree`和`treegrid`用于展示层级结构的数据,可以进行展开、折叠、选择等操作。 7. **菜单和工具栏**:`menu`组件用于创建下拉菜单,`toolbar`组件则可以创建顶部或底部的工具栏,常用于放置按钮...
6. **jquery-easyui-treegrid-dnd**: TreeGrid是EasyUI的一个组件,结合了表格和树形结构。此文件可能演示了如何实现TreeGrid中的行拖放,允许用户重新排序或移动树节点。 7. **datagrid-dnd-tree**: Datagrid是...
TreeGrid 是一个结合了树形结构和表格的控件,非常适合展示层级关系的数据。 示例代码: ```html <table id="treegrid" style="width:100%"> ``` JavaScript 代码: ```javascript $(function(){ $('#treegrid'...
总结来说,这个框架结合了EasyUI的前端便捷性、EasyUITree的树形结构管理以及SpringMVC的后端控制能力,提供了一套完整的解决方案,适用于快速开发需要动态交互和数据展示的Web应用。无论是对于新手还是经验丰富的...
EasyUI 提供了一系列预先设计好的 CSS 样式和 JavaScript 组件,包括表格、表单、窗口、菜单、按钮、树形结构等,使得开发者可以快速地搭建出符合企业需求的管理界面。在本实例中,我们可以预见到包含以下核心知识点...
- **Tree** 和 **TreeGrid**:树形结构,可以显示层级数据,TreeGrid 结合了表格和树的特点。 - **Tabs**:选项卡,方便在多个视图间切换。 - **Menu**:菜单系统,提供下拉菜单和工具栏菜单。 - **Layout**:...
5. **树形视图(tree)与树形表格(treegrid)**:用于展示层级关系的数据,适用于组织结构、目录浏览等场景。 6. **布局(layout)**:EasyUI的布局组件能帮助开发者轻松创建响应式和可调整的页面结构,适应不同...
EasyUI框架是一个基于jQuery的轻量级前端UI库,它为开发者提供了丰富的组件,如表格、下拉框、树形菜单、按钮等,使得构建美观、响应式的Web应用变得更加便捷。在结合Spring MVC这个强大的MVC框架后,可以构建出功能...
8. **表格树(TreeGrid)**:结合了表格和树形控件的功能,适用于展示具有层级关系的表格数据。 9. **下拉框(ComboBox)**:提供下拉列表选择,支持自动完成和远程加载数据。 10. **滑块(Slider)**:用于数值...
- **Tree/TreeGrid**:如果权限结构复杂,可能会使用树形结构来表示,方便用户直观理解角色与权限的层级关系。 5. **Promiss 文件**:这个文件可能是实现系统功能的一部分,可能是Promise对象的实现,用于处理异步...
- **组件化**:EasyUI 提供了许多组件,如对话框、表格、树形视图、菜单、按钮等,这些组件可以方便地组合使用,构建复杂的Web应用界面。 - **数据绑定**:EasyUI 支持与后端数据源进行双向数据绑定,例如,表格可以...
1. **组件丰富**:EasyUI 包含了诸如窗口(Window)、面板(Panel)、菜单(Menu)、表单(Form)、表格(Grid)、树形结构(Tree)、下拉树(TreeCombo)、分页(Pager)等众多组件,满足不同应用场景的需求。...