电商项目笔记之九:商品类别管理


主要是类别是树形的添加和遍历都比较别扭

看看工作流程, 真用的时候还是jQuery搞定吧...

	private void createCategoryTree(){
		String where = "where level=1";//查询一级节点
		PageModel pageModel = categoryDao.find(-1, -1,where ,null);//执行查询方法
		List allCategorys = pageModel.getList();
		map = new LinkedHashMap();//创建新的集合
		for(ProductCategory category : allCategorys){//遍历所有的一级节点
			setNodeMap(map,category,false);//将节点添加到Map集合中
		}
	}

参数中map是树, node是类别, flag代表是否是末节点

如果节点为空就停止遍历, 然后根据读取到节点级别添加制表符和空格

迭代此方法,直到遍历完为止.

	private void setNodeMap(Map map,ProductCategory node,boolean flag){
		if (node == null) {//如果节点为空
			return;//返回空,结束程序运行
		}
		int level = node.getLevel();//获取节点级别
		StringBuffer sb = new StringBuffer();//定义字符串对象
		if (level > 1) {//如果不是根节点
			for (int i = 0; i < level; i++) {
				 sb.append(" ");//添加空格
			}
			sb.append(flag ? "├" : "└");//如果为末节点添加"└",反之添加"├"
		}
		map.put(node.getId(), sb.append(node.getName()).toString());//将节点添加的集合中
		Set children = node.getChildren();//获取其子节点	
		// 包含子类别
		if(children != null &&  children.size() > 0){//如果节点不为空
			int i = 0;
			// 遍历子类别
			for (ProductCategory child : children) {
				boolean b = true;
				if(i == children.size()-1){//如果子节点长度减1为i,说明为末节点
					b = false;//设置布尔常量为false
				}
				setNodeMap(map,child,b);//重新调用该方法
			}
		}
	}


前台显示:



添加子类别:

先判断子类别的数量


				没有子类别
			
			
				
					个子类别
				
			



选定父节点后,添加子类别

添加







你可能感兴趣的:(电商项目笔记之九:商品类别管理)