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>
<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属性设置了一开始显示的时候最大显示的层级