ASP.NET DEMO 16: 如何编程动态创建 TreeView

本文介绍了一种从数据库加载自关联表数据并将其显示在TreeView上的方法。通过递归查询DataTable来创建子节点,提高了加载效率。示例使用ASP.NET2.0实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

优快云 中诸多初学者每每还是在问:如何从数据库加载自关联表数据,并显示到 TreeView 上?
因此,这里提供一个最简单的递归创建模型以供参考。

表模型
关于自关联模型的建立以及涉及的引用完整性约束,有多种策略。
为了简化,此示例中 ParentID=0  表示无实际的父节点。


代码

<%@ Page Language="C#" %>
<%@ Import Namespace="System.Data" %>
<%@ Import Namespace="System.Data.OleDb" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<script runat="server">
    
protected void Page_Load(object  sender, EventArgs e)
    
{
        
if (!IsPostBack) 
{
            CreateTreeView();
        }

    }


    
/// <summary>
    
/// 创建 TreeView
    
///
 此方法采取一次性加载目标数据到 DataTable,递归查询 DataTable ,创建子节点
    
/// </summary>

    private void  CreateTreeView()
    
{
        
//
        const int VirtualRootId = 0// 虚拟的根节点 ID, 表中 ParentID=0 的节点表示无实际父节点

        const string SQL_SELECT = "SELECT NodeId, NodeName,ParentId FROM TreeView ORDER BY NodeId ASC";
        
        
//
        string connStr = "Provider=Microsoft.Jet.OleDb.4.0;data source=" + Server.MapPath("DEMO15_TreeViewDemo.mdb"
); ;        
        
//
        OleDbDataAdapter da = new
 OleDbDataAdapter(SQL_SELECT, connStr);
        DataTable dt 
= new
 DataTable();
        
//
        da.Fill(dt);
        
//
        CreateTreeViewRecursive(treeMenu.Nodes, dt, 0
);
    }


    
/// <summary>
    
/// 递归查询数据,创建 TreeNode 节点
    
/// </summary>

    
/// <param name="nodes"></param>
    
/// <param name="dataSource"></param>
    
/// <param name="parentId"></param>

    private void CreateTreeViewRecursive(TreeNodeCollection nodes, DataTable dataSource, int  parentId)
    
{
        
//
        string fliter = String.Format("ParentId={0}"
, parentId);
        
// 查询子节点

        DataRow[] drArr = dataSource.Select(fliter);
        
        TreeNode node;        
        
foreach(DataRow dr in drArr) 
{                        
            
//
            node = new
 TreeNode();
            nodes.Add(node);
            node.Text 
= (string)dr["NodeName"
];            
            
//
 设置其他属性
            
//
      
                       
            
// 递归创建子节点

            CreateTreeViewRecursive(node.ChildNodes, dataSource, (int)dr["NodeId"]);
            
            
// 移除已添加行,提高性能

            dataSource.Rows.Remove(dr);
        }

    }


</script>

<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
    
<title>ASP.NET DEMO15: CreateTreeViewResursiveFromDb</title>
</head>
<body>
    
<form id="form1" runat="server">
    
<div>
        
<h1>Menu Tree created from DataBase</h1>
        
<a href="http://www.cnblogs.com/Jinglecat/archive/2007/08/10/850090.html">More Details</a>
        
<hr />
        
<asp:TreeView ID="treeMenu" runat="server"  ExpandDepth="1">
        
</asp:TreeView>
    
</div>
    
</form>
</body>
</html>
版本信息
ASP.NET 2.0

完整示例
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值