[jillzhang]ExtJs与WCF交互:生成树 --数据库版补充

 

原文见:
http://www.cnblogs.com/jillzhang/archive/2008/06/15/1222233.html
已经讲得很清楚,本文只是将该篇WCF的方法换成数据库版


1.分类表T_Class主要结构
F_ID  主键ID
F_ClassName 分类名称
F_ParentID 父类ID

 

2.扩展treeNode类

[DataContract]
public   class  treenode
{
[DataMember]
public   string  id;

[DataMember]
public   string  text;

[DataMember]
public  List < treenode >  children  =   new  List < treenode > ();

[DataMember]
public   string  cls;

[DataMember]
public   bool  leaf;

[DataMember]
public   string  parentid;
}

即增加了一个parentid成员

 

3.修改WCF中的方法

[OperationContract]
[WebInvoke(ResponseFormat 
=  WebMessageFormat.Json)]
public  treenode[] GetTree()
{
    
using  (DBDataContext db  =   new  DBDataContext())
    {
    
if  (db.Connection  !=   null   &&  db.Connection.State  !=  System.Data.ConnectionState.Open)
    {
        db.Connection.Open();
    }
    var query 
=  db.T_Classes. Select(c  =>   new  { id  =  c.F_ID, name  =  c.F_ClassName, parentid  =  c.F_ParentID });

    
foreach  (var u  in  query)
    {
        treenode _node 
=   new  treenode();
        _node.id 
=  u.id.ToString().ToLower();
        _node.parentid 
=  u.parentid.ToString().ToLower();
        _node.text 
=  u.name;
        
int  i  =  db.T_Classes.Count(c  =>  c.F_ParentID  ==  u.id);
        
if  (i  >   0 )
        {
        _node.leaf 
=   false ;
        _node.cls 
=   " folder " ;
        }
        
else
        {
        _node.leaf 
=   true ;
        _node.cls 
=   " file " ;
        }
        GenTreeNode(NodeLists, _node);
    }
    db.Connection.Close();
    }
    
return  NodeLists.ToArray();
}

public  List < treenode >  NodeLists  =   new  List < treenode > ();

public  List < treenode >  GenTreeNode(List < treenode >  nodeList, treenode node)
{
    
bool  flag  =   false ;
    
foreach  (treenode n  in  nodeList)
    {
    
if  (n.id  ==  node.parentid)
    {
        n.children.Add(node);
        flag 
=   true ;
        
break ;
    }
    }
    
if  ( ! flag)
    {
    nodeList.Add(node);
    }
    
return  nodeList;
}

 


运行效果图如下:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值