从asp项目中的数据库填充导航菜单? [英] fill navigation menu from database in asp project ?

查看:57
本文介绍了从asp项目中的数据库填充导航菜单?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

hi


i我的数据库中有一个名为menu的菜单

包含(menu_ID,Title,URL)

和数据喜欢(1,HomePage,home.aspx)



因此我可以使用此代码从数据库填写我的导航菜单



dt = MM.Menu_Load(Convert.ToInt32(Session [User_ID]));



for(int i = 0; i< dt.Rows.Count; i ++)

{

DataRow myrow = dt.Rows [i];

MenuItem item = new MenuItem(myrow [Title]。ToString());

item.NavigateUrl = myrow [URL]。ToString();

NavigationMenu.Items.Add(item) ;

}



我的问题是:

我如何将子菜单添加到我的主页,例如

主页 - contactUs?

hi
i have table named menu in my database
which contain ( menu_ID , Title , URL )
and data like ( 1 , HomePage , home.aspx)

so i can fill my navigation menu from database by using this code

dt = MM.Menu_Load(Convert.ToInt32(Session["User_ID"]));

for (int i = 0; i < dt.Rows.Count; i++)
{
DataRow myrow = dt.Rows[i];
MenuItem item = new MenuItem( myrow["Title"].ToString());
item.NavigateUrl = myrow["URL"].ToString();
NavigationMenu.Items.Add(item);
}

my question is :
how can i add child menu to my homepage for example
homepage - contactUs ?

推荐答案

您必须使用父菜单Id将子菜单插入数据库。如果你没有那种模式,那么改变你的表结构。



在每个菜单之后,获取菜单ID并从数据库中检索所有子菜单并将其附加到菜单中。您可以在Google或Bing中搜索示例。
You have to insert the submenu to database with parent menu Id. If you don't have that sort of schema, then alter your table structure.

After that for each menu, take the menu id and retrieve all the submenus from database and append it to the menu. You can search for examples in Google or Bing.


我自己解决它。

dt = MM.Menu_Load(Convert.ToInt32(Session [User_ID ));;

DataRow [] drowpar = dt.Select(ParentID =+ 0);



foreach(DataRow dr在drowpar)

{

NavigationMenu.Items.Add(new MenuItem(dr [Title]。ToString(),

dr [ menu_ID]。ToString(),,

dr [URL]。ToString()));

}



foreach(DataRow dr in dt.Select(ParentID>+ 0))

{

MenuItem mnu = new MenuItem(dr [Title]。ToString(),

dr [menu_ID]。ToString(),

,dr [URL]。ToString() );

NavigationMenu.FindItem(dr [ParentID]。ToString())。ChildItems.Add(mnu);

}
i solve it my self :)
dt = MM.Menu_Load(Convert.ToInt32(Session["User_ID"]));
DataRow[] drowpar = dt.Select("ParentID=" + 0);

foreach (DataRow dr in drowpar)
{
NavigationMenu.Items.Add(new MenuItem(dr["Title"].ToString(),
dr["menu_ID"].ToString(), "",
dr["URL"].ToString()));
}

foreach (DataRow dr in dt.Select("ParentID >" + 0))
{
MenuItem mnu = new MenuItem(dr["Title"].ToString(),
dr["menu_ID"].ToString(),
"", dr["URL"].ToString());
NavigationMenu.FindItem(dr["ParentID"].ToString()).ChildItems.Add(mnu);
}


这篇关于从asp项目中的数据库填充导航菜单?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆