C#树目录(treeView)的编写

 

1,数据库(DAL层)编写

(1)模板的编写

1
2
3
4
5
6
public class CategoryModel{
    public int _CategoryID { get; set; }
    public string _CategoryName { get; set; }
    public string _CategoryPy { get; set; }
    public int _ParentID { get; set; }
}

 (2)从数据库中获取集合

复制代码
        //获取类别信息
        public List<CategoryModel> GetCategoryDal(int ParentID) {
            string str = "select * from Category where ParentID=@ParentID";
            List<CategoryModel> list = new List<CategoryModel>();
            
            SQLiteParameter[] sqlitePara = { new SQLiteParameter("ParentID",ParentID) };
            DbDataReader read= SQLiteHelper.ExecuteReader(str,sqlitePara);
            while (read.Read()) {
                if (read.HasRows) {
                    CategoryModel model = new CategoryModel();
                    model._CategoryID = read.GetInt32(0);
                    model._CategoryName = read.GetString(1);
                    model._CategoryPy = read.GetString(2);
                    model._ParentID = read.GetInt32(3);
                    list.Add(model);
                }
                                   
            }
            return list;
        } 
复制代码

2,(BLL)层

        //获取目录信息
        public List<CategoryModel> GetCategoryInfo(int id)
        {
            ClassDal dal = new ClassDal();
            return  dal.GetCategoryDal(id);
        }

3,树目录的编写

表是这样的

 

 

(用到递归的方   private void TreeGetDate(TreeNodeCollection t,int id)

复制代码
   {
            ClassBll bll = new ClassBll();//新建BLL层类主要为了调用数据库
            List<CategoryModel> list = new List<CategoryModel>();
            list = bll.GetCategoryInfo(id);
//
数据库的数据存在这个集合中(上面的为获取指定parentID的数据)
/*
1,第一次传入0;TreeGetDate(TreeView1.Nodes,0);
则list中的数据为等ParentID为0的数据

*/
for (int i = 0; i < list.Count; i++) { string name = list[i]._CategoryName;// int pid = list[i]._CategoryID; TreeNode tree = t.Add(name); tree.Tag = pid;
/*
接着获取Category的值,把值传给下一次循环
如:下一次为132则 调用
                TreeGetDate(tree.Nodes,132);
                结果就会在tree的子节点上添加
这样的子节点以此类推
*/
tree.ImageIndex
= 0;//显示图片 TreeGetDate(tree.Nodes,pid); } }

复制代码

 

posted @   Restrain  阅读(2054)  评论(0)    收藏  举报
编辑推荐:
· 记一次 .NET某云HIS系统 CPU爆高分析
· 如果单表数据量大,只能考虑分库分表吗?
· 一文彻底搞懂 MCP:AI 大模型的标准化工具箱
· 电商平台中订单未支付过期如何实现自动关单?
· 用 .NET NativeAOT 构建完全 distroless 的静态链接应用
阅读排行:
· 如果单表数据量大,只能考虑分库分表吗?
· 一款让 Everything 更加如虎添翼的 .NET 开源辅助工具!
· (原创)[开源][.Net Framework 4.5] SimpleMVVM(极简MVVM框架)更
· 冲压车间软件实施
· 干货分享!MCP 实现原理,小白也能看懂
点击右上角即可分享
微信分享提示