常用的在数据库中建立无限级树形菜单的asp.net代码

 更新时间:2008年09月26日 17:56:01   作者:  
经常在项目中遇到建立无限级树形菜单展示的效果,这里简单地做了一个,基本后台代码如下
复制代码 代码如下:

private DataTable GetTable(int topid)
{
DataTable dt = null;
try
{
string constr = "server=.;database=tqnpc;uid=sa;pwd=sa";
string selstr = "select * from RW_工作关系 where main_id=" + topid + "";
SqlConnection con = new SqlConnection(constr);
SqlDataAdapter da = new SqlDataAdapter(selstr, con);
dt = new DataTable();
da.Fill(dt);
}
catch (Exception ex)
{
Response.Write(ex.Message);
}
return dt;
}

protected void MakeTree()
{
DataTable dt = GetTable(0);
try
{
if (dt != null)
{
for (int i = 0; i < dt.Rows.Count; i++)
{
TreeNode tn = new TreeNode();
tn.Text = dt.Rows[i]["MAIN_ID"].ToString();
tn.Value = dt.Rows[i]["REF_ID"].ToString();
tn.SelectAction = TreeNodeSelectAction.Select;
TreeView1.Nodes.Add(tn);
AddTreeNodes(int.Parse(dt.Rows[i]["REF_ID"].ToString()), int.Parse(dt.Rows[i]["REF_ID"].ToString()), tn);
}
}
}
catch (Exception ex)
{
Response.Write(ex.Message);
}
}

这个方法对数据库的结构也有一定的要求,数据库的设计如下:

相关文章

  • RadioButtonList绑定图片及泛型Dictionary应用

    RadioButtonList绑定图片及泛型Dictionary应用

    读取站点某一目录的图片,需要掌握LINQ与泛型Dictionary<TKey,TValue>的使用,本文将介绍RadioButtonList绑定图片的实现,感兴趣的朋友可以了解下,或许对你有所帮助
    2013-02-02
  • ASP.NET Core为Ocelot网关配置Swagger

    ASP.NET Core为Ocelot网关配置Swagger

    这篇文章介绍了ASP.NET Core为Ocelot网关配置Swagger的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-04-04
  • 扩展方法ToJSON() and ParseJSON()

    扩展方法ToJSON() and ParseJSON()

    AJAX编程经常需要Object<=>JSON之间转换,写了二个扩展方法: public static string ToJSON(this object obj) public static T ParseJSON<T>(this string str)
    2008-03-03
  • asp.net Cookie跨域、虚拟目录等设置方法

    asp.net Cookie跨域、虚拟目录等设置方法

    Cookie跨域、虚拟目录等设置方法,需要的朋友可以参考下。
    2009-11-11
  • ASP.Net巧用窗体母版页实例

    ASP.Net巧用窗体母版页实例

    这篇文章主要介绍了ASP.Net巧用窗体母版页的方法,以实例形式详细分析了母版页的用途及嵌套用法,具有一定的学习借鉴价值,需要的朋友可以参考下
    2014-11-11
  • 简单几步 实现vs2010对html5的支持

    简单几步 实现vs2010对html5的支持

    微软从来不会让程序员用记事本写代码,如今html5马上就要火起来vs2010怎么会不支持html5呢?月月bird我将vs2010支持html5的方法整理了一下。
    2016-05-05
  • 详解Asp.Net Core 2.1+的视图缓存(响应缓存)

    详解Asp.Net Core 2.1+的视图缓存(响应缓存)

    本篇文章给大家通过实例讲述了Asp.Net Core 2.1+的视图缓存(响应缓存)的相关知识点,对此有兴趣的读者们可以学习下。
    2018-03-03
  • ADO.NET基础知识汇总

    ADO.NET基础知识汇总

    程序和数据库交互,要通过ADO.NET进行;通过ADO.NET就能在数据库中执行SQL了 。ADO.NET中提供了对不同数据库的统一操作接口(ODBC) 。另外还有一种操作数据库的接口是JDBC
    2015-11-11
  • .NET6+Quartz实现定时任务的示例详解

    .NET6+Quartz实现定时任务的示例详解

    在实际工作中,经常会有一些需要定时操作的业务,如:定时发邮件,定时统计信息等,那么如何实现才能使得我们的项目整齐划一呢?本文通过一些简单的小例子,简述在.Net6+Quartz实现定时任务的一些基本操作,如有不足之处,还请指正
    2023-03-03
  • MVC4制作网站教程第二章 部分用户功能实现代码

    MVC4制作网站教程第二章 部分用户功能实现代码

    这篇文章主要为大家详细介绍了MVC4制作网站教程,部分用户功能实现代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-08-08

最新评论