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

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

java代码:[code]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();[/code]里面的循环我相信程序猿都能看懂吧!
我查询按照level来排序,查询结果:
name, level
成都 1
武侯区 1.1
青羊区 1.2
锦江区 1.3
上东锦城 1.3.1
金牛区 1.4
成华区 1.5
这样以来一目了然了吧,直接按顺序生成树!
flex端:[code]<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" />[/code]欢迎大家来探讨更好的算法!本人邮箱[email]136006280@qq.com[/email]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值