使用asp:Menu控件以编程方式从数据库生成菜单不起作用

时间:2012-04-03 03:38:53

标签: c# asp.net webforms aspmenu-control

我正在尝试使用以下示例从数据库创建动态菜单 http://www.dotnetfunda.com/articles/article1477-how-to-create-a-menu-in-aspnet-using-aspmenu-control.aspx

我修改了下面发布的代码只显示父菜单但没有显示子菜单,我确定在调试代码时出现问题我注意到它没有进入 foreach (dvMenu中的DataRowView行) AddChildItems 功能

我的SQL查询就像

Select PageID, PageName,PageInternalLinkURL, PageInheritance from pg_Pages

我使用的代码段

<asp:Menu ID="Menu1" runat="server" Orientation="Horizontal" >

// I am convert ds to table for now.
DataTable table = dsMenu.Tables[0]; ;
DataView dvMenu = new DataView(table);
dvMenu.RowFilter = "PageInheritance is NULL";
foreach (DataRowView row in dvMenu)
{
MenuItem menuItem = new MenuItem(row["PageName"].ToString(), row["PageId"].ToString());
menuItem.NavigateUrl = row["PageURL"].ToString() + "?PageId=" + row["PageId"] + "&Language=" + sLangCode;
Menu1.Items.Add(menuItem);
AddChildItems(dvMenu.Table, menuItem);
}

//Function to look for child menu
    private static void AddChildItems(DataTable table, MenuItem menuItem)
    {
        DataView viewItem = new DataView(table);
        viewItem.RowFilter = "PageInheritance = " + menuItem.Value;
        foreach (DataRowView childView in viewItem)
        {
            MenuItem childItem = new MenuItem(childView["PageName"].ToString(),
            childView["PageId"].ToString());
            childItem.NavigateUrl = childView["PageURL"].ToString();
            menuItem.ChildItems.Add(childItem);
            AddChildItems(table, childItem);
        }
    }

我不确定我做错了什么。根据我的数据库,它应该显示行 Page2 的子菜单。当为匹配子行调用AddChildItems函数时,它只是熟悉循环并且不显示子行中的任何内容。

使用当前代码输出

首页|第2页第3页|第4页

1 个答案:

答案 0 :(得分:0)

回答代码或逻辑是没有错的,SQL查询在修复查询后得到错误的数据就像魅力一样。