• TreeView无限极分类绑定(从数据库读取数据源)


    TreeView这个控件其实我本来不怎么会用到,今天有一个项目要用到,而且是 无限极的分类数据绑定,于是就根据自己以前写过的代码别写出了这个无限极分类的例子,呵呵希望能够对大家有所帮助,本人尽量把注释写的详细一些把,因为有 的时候搜问题到别人的博客,写的代码完全看不懂,每个人写代码可能都有一定的习惯,所以一定要多写一些注释让别人看懂!

    首先说一下我的数据库结构

    Pid                主键自动增长

    PartName       分类名称

    ParentId        父级ID

    相信大家一定都会很熟悉吧,这是无限极分类比较常用的一种设计思路!好了接下来看代码吧,自己认为这个还是很强大的,使用了递归的操作,大大减少了代码量!

            /// <summary>  
            
    /// 控件绑定父节点 
            
    /// </summary>  
            private void TreeViewBind()
            {
                DataSet ds 
    = pbll.GetList("");   //数据源读取所有数据
                DataView dv = ds.Tables[0].DefaultView;
                dv.RowFilter 
    = "ParentId=0";   //筛选ParentId=0为顶级分类
                TreeView1.ShowCheckBoxes = TreeNodeTypes.All;
                
    foreach (DataRowView drv in dv)
                {
                    TreeNode node 
    = new TreeNode();
                    node.Text 
    = drv["PartName"].ToString();
                    node.Value 
    = drv["Pid"].ToString();
                    node.Expanded 
    = false;
                    TreeView1.Nodes.Add(node);
                    AddReplies(dv, node);
                }
            }
            
    /// <summary>  
            
    /// 递归绑定子节点  
            
    /// </summary>  
            
    /// <param name="dv"></param>  
            
    /// <param name="node"></param>  
            private void AddReplies(DataView dv, TreeNode node)
            {
                dv.RowFilter 
    = "ParentId='" + node.Value + "'";
                
    foreach (DataRowView row in dv)
                {
                    TreeNode replyNode 
    = new TreeNode();
                    replyNode.Text 
    = row["PartName"].ToString();
                    replyNode.Value 
    = row["Pid"].ToString();
                    replyNode.Expanded 
    = false;
                    node.ChildNodes.Add(replyNode);
                    AddReplies(dv, replyNode);
                }
            }
    联盟快卖 商人,生意人,待创业人士在此可以共赢互利 期待你的加入 群号:140809277
  • 相关阅读:
    Hibernate学习笔记
    Oracle12c 在windonServer2012中安装的步骤
    提升tomcat服务器性能的七条经验
    zyUpload---照片上传并显示效果
    js的隐含参数(arguments,callee,caller)使用方法
    js中callback.call()和callback()的区别
    理解javascript中的回调函数(callback)
    Spring MVC 流程图
    JDBC在springMvc等框架中使用的方式
    为IE8添加EventListener系列方法支持
  • 原文地址:https://www.cnblogs.com/yexinw/p/2107434.html
Copyright © 2020-2023  润新知