`

easyUI-树形菜单(ComboTree) 无限层级树实现方式

阅读更多

     对于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
	private String fatherName;				//父角色名称
	
	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>> comboTreeList  =new ArrayList<Map<String,Object>>();

/**
 * 返回 treeGrid(树形表格)需要的json格式数据
 * 前端调用的就是这个方法
 */
@SuppressWarnings("unchecked")
public String backComboTreeTreeRole(){
        //得到所有角色
	List<Role> list = roleService.getRoleAll();
	
	//调用方法实现角色树
	createComboTreeTree(list,"0");
	
	//将集合转换为json输出到页面
	Gson gson = new Gson();
	String json = gson.toJson(comboTreeList);
	
	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 createComboTreeTree(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>();
			//这里必须要将对象角色的id、name转换成ComboTree在页面的显示形式id、text
			//ComboTree,不是数据表格,没有在页面通过columns转换数据的属性
			map.put("id", list.get(i).getId());			//id
			map.put("text",list.get(i).getName());		//角色名
			map.put("children", createComboTreeChildren(list, role.getId()));
		}
		if (map != null)
			comboTreeList.add(map);
	}
}


/**
 * 递归设置role树
 * @param list
 * @param fid
 * @return
 */
private List<Map<String, Object>> createComboTreeChildren(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>();
			//这里必须要将对象角色的id、name转换成ComboTree在页面的显示形式id、text
			//ComboTree,不是数据表格,没有在页面通过columns转换数据的属性
			map.put("id", list.get(j).getId());
			map.put("text", list.get(j).getName());
			map.put("children", createComboTreeChildren(list, treeChild.getId()));
		}
		
		if (map != null)
			childList.add(map);
	}
	return childList;
}

  

 

    jsp页面代码:

<td>
	<input type="text" name="role.fatherId" <#if role.fatherId == ""> value="0" <#else> value="${role.fatherId}" </#if> hidden = "true"/>
	<div id= "comboTree" style="margin-left:0; high:60px; padding-bottom:2px; padding-top:2px; width:210px;"></div>
</td>

   

    js代码:

$(function(){
	//加载树
	$('#comboTree').combotree({      
        url:'role!backComboTreeTreeRole.action',
        onClick:function(node){
    		//单用户单击一个节点的时候,触发
        	$("input[name='role.fatherId']").val(node.id);
    	},
        checkbox:false,
        multiple:false
    });
});

 

 

 


 

  • 大小: 5.5 KB
分享到:
评论
1 楼 bkhacker 2016-12-12  

相关推荐

    easyui中文帮助文档

    `easyui-tree` 用于创建和管理树形数据结构,通常用于展示层级关系的信息。它支持展开/折叠节点、添加/删除节点、以及节点的点击事件处理。 6. **easyui-datagrid (表格)** `easyui-datagrid` 是一个强大的表格...

    jquery easyui

    12. **easyui-combotree (组合树形框)**:`easyui-combotree` 结合了下拉框和树形结构,用户可以选择树中的某个节点作为值,适用于具有层级关系的数据选择。 13. **easyui-layout (布局)**:`easyui-layout` 提供了...

    jquery-easyui-1.3.5 中文离线API

    EasyUI 的核心在于它的组件系统,这些组件包括但不限于:对话框(dialog)、表格(datagrid)、表单(form)、菜单(menu)、工具栏(toolbar)、树形控件(tree)、下拉树(combotree)、下拉列表(combobox)等。...

    jQuery EasyUI 1.4.3 版 API 中文版

    首先,jQuery EasyUI 的核心组件包括对话框(dialog)、表单(form)、数据网格(datagrid)、树形控件(tree)、下拉树(combotree)、菜单(menu)等。这些组件可以帮助开发者快速构建功能丰富的用户界面,无需...

    easyui 异步树

    在 EasyUI 中,"异步树" 是一种非常重要的组件,它允许用户在无需一次性加载所有数据的情况下,根据需要动态地加载树形结构的数据。这种特性对于处理大量数据或层次复杂的结构尤其有用,可以显著提升用户体验,减少...

    ThinkPHP+EasyUI之ComboTree中的会计科目树形菜单实现方法

    ComboTree是EasyUI组件库中的一个控件,用于生成树形菜单,它能够展示节点的层级关系。 在本文中,将介绍如何使用ThinkPHP和EasyUI框架结合实现会计科目的树形菜单。具体实现过程会涉及到ThinkPHP的模型层编程以及...

    jQueryEasyUI中文框架使用文档

    - **组合树(ComboTree)**:结合了下拉列表和树形结构,适用于层级选择。 - **数字框(NumberBox)**:限制输入的数值框,可以设置步进值。 - **验证框(ValidateBox)**:自动验证输入字段的合法性。 - **日期输入框...

    easyui用户手册

    树形控件(Tree)非常适合用来展示层级结构的数据。 ```javascript $('#tt').tree({ data: [{ text: 'Item1', children: [{ text: 'Sub Item1' }, { text: 'Sub Item2' }] }] }); ``` ##### 创建异步树 对于...

    easyui1.3.4API

    - **树形控件(Tree)**: 展示层级结构数据,支持拖放、节点操作。 - **表单验证(Validator)**: 自动验证表单字段,提供多种验证规则。 - **联动下拉(ComboboxLinkage)**: 实现两个或多个下拉框之间的联动...

    easyui帮助

    ComboBoxTree 结合了下拉框和树形结构,适用于选择具有层级关系的数据。用户可以展开节点查看子项,选择后自动回填到输入框中。 5. **菜单(Menu)** Menu组件可以创建多级菜单,常用于网站导航或右键快捷菜单。...

    jquery_easyui 很全面中文文档

    ##### 2.12 Combotree 组合树形框 - **特点**: 结合了树形结构和下拉列表的功能。 - **使用场景**: 适用于需要从具有层级关系的选项中选择的场景。 ##### 2.13 Layout 布局 - **特点**: 提供了布局容器,支持多种...

    jquery ui 树状下拉选择框

    jQuery EasyUI 是一款基于 jQuery 的前端 UI 库,提供了许多通用的布局和显示组件,如表单验证、Tab 导航、拖放效果、表格排序、DataGrid、树形菜单等。其目标是简化网站用户界面的构建过程。 #### 四、树状下拉...

Global site tag (gtag.js) - Google Analytics