using System;
using System.Collections;
using System.Configuration;
using System.Data;
using System.Linq;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Xml.Linq;

using System.Data.SqlClient;

namespace WebApp
{
    public partial class LoadMenu : System.Web.UI.Page
    {
        DataSet ds = null;

protected void Page_Load(object sender, EventArgs e)
        {
            if (!IsPostBack)
            {
                //this.InitPage();

ds = GetDB("select * from page");
                TreeNode pTreeNpd = null;
                GetTreeNode("0",pTreeNpd);
            }
        }

private void InitPage()
        {
            TreeNode treeNode = this.GetTreeNode();
            this.TreeViewMenu.Nodes.Add(treeNode);
        }

private TreeNode GetTreeNode()
        {
            TreeNode treeNode = new TreeNode("菜单导航");
            DataSet ds = this.GetDB("select * from page where Parent = '0'");
            foreach (DataRow masterRow in ds.Tables[0].Rows)
            {
                    TreeNode masterNode = new TreeNode((string)masterRow["Text"]);
                    masterNode.NavigateUrl = (string)masterRow["Page"];
                    treeNode.ChildNodes.Add(masterNode);

DataSet ds11 = this.GetDB("select * from page where Parent = '" + masterRow["RID"] + "'");
                    foreach (DataRow item in ds11.Tables[0].Rows)
                    {
                        TreeNode masterNode1 = new TreeNode((string)item["Text"]);
                        masterNode1.NavigateUrl = (string)item["Page"];
                        masterNode.ChildNodes.Add(masterNode1);
                    }

}
            return treeNode;
        }

private TreeNode GetTreeNode(string Parent, TreeNode treeNode)
        {
            DataView dv = ds.Tables[0].DefaultView;
            dv.RowFilter = " [Parent]='" + Parent + "'";
            foreach (DataRowView item in dv)
            {
                TreeNode tttrr = new TreeNode();
                if (treeNode == null)
                {
                    tttrr.Text = item["Text"].ToString();
                    TreeViewMenu.Nodes.Add(tttrr);

GetTreeNode(item["rid"].ToString(), tttrr);
                }
                else
                {
                    tttrr.Text = item["Text"].ToString();
                    tttrr.NavigateUrl = (string)item["Page"];
                    treeNode.ChildNodes.Add(tttrr);
                }

}
            return null;
        }

private DataSet GetDB(string sql)
        {
            SqlConnection con = new SqlConnection();
            con.ConnectionString = “";
            if(con.State == ConnectionState.Closed)
            {
                con.Open();
            }

SqlDataAdapter da = new SqlDataAdapter(sql, con);

DataSet ds = new DataSet();
            da.Fill(ds);

return ds;
        }
    }
}

Asp.net树形递归算法的更多相关文章

  1. asp.net 树形控件 $.fn.zTree.init

    在网页中通过jquery脚本来构筑树形控件将是一个不错的选择,比如有一个文本框,当鼠标点击的时候,像弹出一个下拉框一样弹出一个树形控件,这似乎是一个不错的控制.下面主要讲讲这种树形控件的实现.为了能使 ...

  2. ASP.NET使用递归算法实现画树程序

    实现效果如下:(随机生成) using System; using System.Collections.Generic; using System.ComponentModel; using Sys ...

  3. ASP.NET树形控件TreeView的递归绑定

    来自:http://blog.csdn.net/xqf003/article/details/4958727

  4. Jquery树形控件 $.fn.zTree.init

    https://www.cnblogs.com/jin-/p/4646202.html asp.net 树形控件 $.fn.zTree.init 在网页中通过jquery脚本来构筑树形控件将是一个不错 ...

  5. 【Tree 1】树形结构数据呈现的递归算法实现

    一.基本概况 在我的项目中,常常会用到树形结构的数据,最为明显的就是左边菜单栏,类似于window folder一样的东西. 而我之前一直是借助前端封装好的ZTree等工具实现展示,而后台则通常使用递 ...

  6. Asp.Net MVC页面静态化功能实现二:用递归算法来实现

    上一篇提到采用IHttpModule来实现当用户访问网站的时候,通过重新定义Response.Filter来实现将返回给客户端的html代码保存,以便用户下一次访问是直接访问静态页面. Asp.Net ...

  7. 使用递归算法结合数据库解析成java树形结构

    使用递归算法结合数据库解析成java树形结构 1.准备表结构及对应的表数据a.表结构: create table TB_TREE ( CID NUMBER not null, CNAME VARCHA ...

  8. 递归算法结合数据库 解析 java树形结构

    1.准备表结构及对应的表数据a.表结构: create table TB_TREE ( CID NUMBER not null, CNAME VARCHAR2(50), PID NUMBER //父节 ...

  9. 在ASP.NET MVC下实现树形导航菜单

    在需要处理很多分类以及导航的时候,树形导航菜单就比较适合.例如在汽车之家上: 页面主要分两部分,左边是导航菜单,右边显示对应的内容.现在,我们就在ASP.NET MVC 4 下临摹一个,如下: 实现的 ...

随机推荐

  1. 通过命令行安装Android app

    手动安装安卓app的命令为:adb install -r C:\Users\Lihao\workspace\Appium_Demo\apps\app_F_1.3.0.apk

  2. 转载: scikit-learn学习之K-means聚类算法与 Mini Batch K-Means算法

    版权声明:<—— 本文为作者呕心沥血打造,若要转载,请注明出处@http://blog.csdn.net/gamer_gyt <—— 目录(?)[+] ================== ...

  3. SwitchyOmega

    SwitchyOmega下载安装地址: http://switchyomega.com/download.html GFWList.bak.txt教程 {"+GFWed":{&qu ...

  4. Keepalived 双机web服务宕机检测切换系统软件

    简介 Keepalived的作用是检测web服务器的状态,如果有一台web服务器死机,或工作出现故障,Keepalived将检测到,并将有故障的web服务器从系统中剔除,当web服务器工作正常后Kee ...

  5. HTML5 javascript修改canvas的大小

    方法1: 设定固定的值,这种方式跟在html中设定canvas的值没有什么区别: window.onload = function(){ canvas.height = 100; canvas.wid ...

  6. 轻量级开源内存数据库SQLite性能测试

    [IT168 专稿]SQLite是一款轻型的数据库,它占用资源非常的低,同时能够跟很多程序语言相结合,但是支持的SQL语句不会逊色于其他开源数据库.它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品 ...

  7. 黄聪:WordPress图片插件:Auto Highslide修改版(转)

    一直以来很多人都很喜欢我博客使用的图片插件,因为我用的跟原版是有些不同的,效果比原版的要好,他有白色遮罩层,可以直观的知道上下翻图片和幻灯片放映模式.很多人使用原版之后发现我用的更加帅一些,于是很多人 ...

  8. You need to use a Theme.AppCompat theme

    java.lang.RuntimeException: Unable to start activity ComponentInfo{com.dji.sdk.sample/com.dji.sdk.sa ...

  9. SOA_环境安装系列2_Oracle RCU安装和环境搭建(案例)

    2015-01-02 Created By BaoXinjian

  10. Linux Tcpdump 使用举例 ---持续更新

    举例: 保存到文件tcpdump -w xxx.cap(默认抓取eth0的包) 抓eth1的包 tcpdump -i eth1 -w /tmp/xxx.cap 抓到完成的数据包(默认只抓前68字节) ...