5

我找到了如何将 asp:Menu 绑定到 XML。我找到了如何将 asp:Menu 绑定到站点地图(实际上将其绑定到 XML)。如何将 asp:Menu 绑定到数据库?

.NET Framework 提供多个数据源:

我想使用一个代表 SQL Server 表中的数据的。数据以每个人都使用的标准分层格式存储:

NodeID    ParentNodeID    Caption        Url
========  ==============  =========      =================
{3234...  {3632...        stackoverflow  http://stackov...
{3632...  (null)          Questions      ~/questions.aspx
{3233...  (null)          Tags           ~/tags.aspx
{3235...  {3632...        google         http://www.goo...

返回所有行的查询将是:

SELECT * FROM Nodes

微软打算用什么秘密方法将这些数据混入 asp:Menu 中?


更新: aspalliance.com 上有一篇很好的文章:Building a Database Driven Hierarchical Menu using ASP.NET 2.0。不幸的是,它描述了如何执行 XML 数据绑定;虽然我对数据库绑定感兴趣。

4

2 回答 2

10

aspalliance.com 上有一篇很好的文章:Building a Database Driven Hierarchical Menu using ASP.NET 2.0。每个步骤都有解释和很好的说明。

“在本文中,Michael 演示了如何使用 ASP.NET 2.0 仅用几行代码创建一个数据库驱动的分层菜单。对于需要功能强大且灵活且设计简单的专业菜单的每个人来说,这是一个必读的教程。 "

的代码可能是:

protected void LoadData()
{
    DataSet ds = new DataSet();
    string connStr = YOUR_CONNECTION_STRING_HERE;
    using(SqlConnection conn = newSqlConnection(connStr))
    {
      string sql = "Select NodeID, Caption, Url, ParentID from Menu";
      SqlDataAdapter da = newSqlDataAdapter(sql, conn);
      da.Fill(ds);
      da.Dispose();
    }
    ds.DataSetName = "Menus";
    ds.Tables[0].TableName = "Menu";
    DataRelation relation = newDataRelation("ParentChild",
     ds.Tables["Menu"].Columns["NodeID"],
     ds.Tables["Menu"].Columns["ParentID"], true);

    relation.Nested = true;
    ds.Relations.Add(relation);

    xmlDataSource.Data = ds.GetXml();
}
于 2008-11-12T16:02:14.490 回答
4

该菜单不支持绑定到 SqlDataSource,因为它是 HierarchicalDataBoundControl - 仅支持分层数据源。您应该实现自己的 HierarchicalDataSourceControl。在这里查看一个例子。或者,您可以创建一个自定义站点地图提供程序并使用 SiteMapDataSource,如此处所示。最后,您可以使用可以绑定到 SqlDataSource的第 3 方控件。

于 2008-11-13T23:35:42.010 回答