java只需一个查询生成xml树传至flex绑定tree

本人用的是blazeds进行flex与java通信的,昨天研究了一天的树绑定,有用arraycollection来绑定,但这需要java端arraylist的时候每一个子节点必须加一个children,感觉很繁琐,还有就是直接在java端生成xml字符串,传至flex端进行强制转换成xml与tree绑定。前奏就不必多说,直奔主题:
首先介绍本人数据表的设计,
name,level
成都    1
武侯区  1.1
青羊区  1.2
锦江区  1.3
金牛区  1.4
成华区  1.5
上东锦城 1.3.1
这样设计表结构的目的就是为了一次性查询出树的所有节点信息,且排序直接生成树

java代码:
StringBuffer sb = new StringBuffer();
		int i = -1;
		 try {
			 //查找该节点下所有子节点
				List<Contactgroup> list = contactgroupDao.findByHql(ContactgroupDao.FIND_BY_LEVEL, level + "%");
				for(Contactgroup group : list) {
					int j = group.getLevel().split("\\.").length;
					if( j > i){
						sb.append("<item name=\""+group.getGngName()+"\" value=\""+group.getLevel()+"\">\n");
					}else{
						for(int k = -1;k < i - j;k++){
							sb.append("</item>\n");
						}
						sb.append("<item name=\""+group.getGngName()+"\" value=\""+group.getLevel()+"\">\n");
					}
					i = j;
				}
				//最后一个j为0 
				for(int m = 0;m < i;m++){
					sb.append("</item>\n");
				}
		 } catch (Exception e) {
			 e.printStackTrace();
		 }
		 return sb.toString();
里面的循环我相信程序猿都能看懂吧!
我查询按照level来排序,查询结果:
name,    level
成都        1
武侯区      1.1
青羊区      1.2
锦江区      1.3
上东锦城    1.3.1
金牛区      1.4
成华区      1.5
这样以来一目了然了吧,直接按顺序生成树!
flex端:
<mx:Script>
		<![CDATA[	
public function loadTree():void{
		    	this.contactAction.findSubgroup("1");
		   }
		    public function findSubgroupResult(e:ResultEvent):void{
			    var arr:XMLList=XMLList(e.result);//把结果转化成XMLList
			    this.tree.dataProvider=arr;
		   }
		   //展开树
            private function tree_itemClick(evt:ListEvent):void { 
                var item:Object = Tree(evt.currentTarget).selectedItem; 
                if (tree.dataDescriptor.isBranch(item)) { 
                    tree.expandItem(item, !tree.isItemOpen(item), true); 
                } 
                Alert.show(item.@value);
            } 

	]]>
	</mx:Script>

			<mx:Tree id="tree" 
	            itemClick="tree_itemClick(event);"  
	            labelField="@name" 
	            labelFunction="tree_labelFunc" 
	            creationComplete="loadTree()"
	            top="30" bottom="0" left="0" width="142" 
	            backgroundColor="#FDFDFD" />
欢迎大家来探讨更好的算法!本人邮箱[email][email protected][/email]

你可能感兴趣的:(算法,Flex,树,blazeds,children)