java只需一个查询生成xml树传至flex绑定tree
程序员文章站
2022-07-12 23:42:57
...
本人用的是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代码:
我查询按照level来排序,查询结果:
name, level
成都 1
武侯区 1.1
青羊区 1.2
锦江区 1.3
上东锦城 1.3.1
金牛区 1.4
成华区 1.5
这样以来一目了然了吧,直接按顺序生成树!
flex端:
首先介绍本人数据表的设计,
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]136006280@qq.com[/email]