java只需一个查询生成xml树传至flex绑定tree
1.本人用的是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代码:
Java代码- 1.StringBuffer sb = new StringBuffer();
- 2.int i = -1;
- 3.try {
- 4.//查找该节点下所有子节点
- 5.List<Contactgroup> list = contactgroupDao.findByHql(ContactgroupDao.FIND_BY_LEVEL, level + "%");
- 6.for(Contactgroup group : list) {
- 7.int j = group.getLevel().split("\\.").length;
- 8.if( j > i){
- 9.sb.append("<item name=\""+group.getGngName()+"\" value=\""+group.getLevel()+"\">\n");
- 10.}else{
- 11.for(int k = -1;k < i - j;k++){
- 12.sb.append("</item>\n");
- 13.}
- 14.sb.append("<item name=\""+group.getGngName()+"\" value=\""+group.getLevel()+"\">\n");
- 15.}
- 16.i = j;
- 17.}
- 18.//最后一个j为0
- 19.for(int m = 0;m < i;m++){
- 20.sb.append("</item>\n");
- 21.}
- 22.} catch (Exception e) {
- 23.e.printStackTrace();
- 24.}
- 25.return sb.toString();
复制代码 里面的循环我相信程序猿都能看懂吧!
我查询按照level来排序,查询结果:
name, level
成都 1
武侯区 1.1
青羊区 1.2
锦江区 1.3
上东锦城 1.3.1
金牛区 1.4
成华区 1.5
这样以来一目了然了吧,直接按顺序生成树!
flex端:
Java代码
Java代码- 1.<mx:Script>
- 2.<![CDATA[
- 3.public function loadTree():void{
- 4. this.contactAction.findSubgroup("1");
- 5. }
- 6. public function findSubgroupResult(e:ResultEvent):void{
- 7. var arr:XMLList=XMLList(e.result);//把结果转化成XMLList
- 8. this.tree.dataProvider=arr;
- 9. }
- 10. //展开树
- 11. private function tree_itemClick(evt:ListEvent):void {
- 12. var item:Object = Tree(evt.currentTarget).selectedItem;
- 13. if (tree.dataDescriptor.isBranch(item)) {
- 14. tree.expandItem(item, !tree.isItemOpen(item), true);
- 15. }
- 16. Alert.show(item.@value);
- 17. }
- 18.
- 19.]]>
- 20.</mx:Script>
- 21.
- 22.<mx:Tree id="tree"
- 23. itemClick="tree_itemClick(event);"
- 24. labelField="@name"
- 25. labelFunction="tree_labelFunc"
- 26. creationComplete="loadTree()"
- 27. top="30" bottom="0" left="0" width="142"
- 28. backgroundColor="#FDFDFD" />
- 29.
- 30.
复制代码 |