ASP.NET+SQL Server利用XML实现动态菜单

一. XML数据类型SQL Server 的存取(SQL Server 2005或2008)

1. 将XML类型的数据存入DB

注: [SPPRF]在DB中的类型要是XML类型的。

SqlParameter sp = new SqlParameter();
sp.SqlDbType 
= SqlDbType.Xml;
System.Xml.XmlReader xr 
= System.Xml.XmlReader.Create(@"E:\a.xml");
string strSqlConn = "#########";
string strSelectSQL = "INSERT INTO [QAUSER]([USRID],[USPWD],[SPPRF]) ";
strSelectSQL 
+= "VALUES('test','123',@xml)";
SqlConnection SqlConn 
= new SqlConnection(strSqlConn);
SqlCommand SqlCmd 
= new SqlCommand(strSelectSQL, SqlConn);
SqlCmd.Parameters.Add(
"@xml", SqlDbType.Xml).Value = xr;
SqlConn.Open();
SqlCmd.ExecuteNonQuery();

2. 取出XML 

 

二. 将XML绑定ASP.NET 中的控件

  使用XmlDataSource动态地加载xml文件并形成不同的菜单

XmlDataSource设置
<asp:XmlDataSource ID="XmlDataSource1"   runat="server" DataFile="~/Test/XMLFile.xml"></asp:XmlDataSource>
导航文件
<?xml version="1.0" encoding="utf-8" ?>
<menu   title="导航" description="">
<menuItem url="http://www.baidu.com" title="网易" description=""/>
<menuItem url="http://www.google.cn" title="新浪" description="" />
<menuItem url="http://www.163.com" title="126" description=""/>
<menuItem url="http://www.126.com" title="其它" description=""/>
</menu>
asp:menu中的属性定义
<asp:Menu ID="Menu1" runat="server" Orientation="Horizontal" DataSourceID="XmlDataSource1"
StaticDisplayLevels
="2" >
<DataBindings>
<asp:MenuItemBinding DataMember="menu" Depth="0" TextField="title"   />
<asp:MenuItemBinding DataMember="menuItem" Depth="1" NavigateUrlField="url" TextField="title" />
</DataBindings>
</asp:Menu>

 

  MenuItemBinding中定义出不同的层次来,并给datamemeber定义出数据来源来,比如说第一个级别datamember中的层次就是0层级,第二个层级的数据源就是menuitem

  由于第一个节点是根结点,一般不用设置NaviateUrlField这个属性

 

  StaticDisplayLevels属性设置了一开始显示的时候最大显示的层级


posted on 2009-03-24 21:24  LongSky  阅读(722)  评论(0编辑  收藏  举报

导航