通常,我们使用SiteMapDataSource控件做为 TreeView控件的数据源,而SiteMapDataSource控件的StartingNodeUrl属性可以设置它从哪个节点开始读取地图文件 (.sitemap),这样,对不同的登录用户设置不同的StartingNodeUrl属性值,就能达到不同的用户登录后显示不同菜单的效果。
示例代码
Web.sitemap:
复制内容到剪贴板
程序代码
<?xml version="1.0" encoding="utf-8" ?>
<siteMap xmlns="http://schemas.microsoft.com/AspNet/SiteMap-File-1.0" >
<siteMapNode>
<siteMapNode url="Manager" title="管理平台">
<siteMapNode url="AA.aspx" title="ManagerMenu1"></siteMapNode>
<siteMapNode url="BB.aspx" title="ManagerMenu2"></siteMapNode>
<siteMapNode url="CC.aspx" title="ManagerMenu3"></siteMapNode>
</siteMapNode>
<siteMapNode url="Employee" title="管理平台">
<siteMapNode url="DD.aspx" title="EmployeeMenu1"></siteMapNode>
<siteMapNode url="EE.aspx" title="EmployeeMenu2"></siteMapNode>
</siteMapNode>
<siteMapNode url="Accountant" title="管理平台">
<siteMapNode url="FF.aspx" title="AccountantMenu1"></siteMapNode>
<siteMapNode url="GG.aspx" title="AccountantMenu2"></siteMapNode>
</siteMapNode>
</siteMapNode>
</siteMap>
<siteMap xmlns="http://schemas.microsoft.com/AspNet/SiteMap-File-1.0" >
<siteMapNode>
<siteMapNode url="Manager" title="管理平台">
<siteMapNode url="AA.aspx" title="ManagerMenu1"></siteMapNode>
<siteMapNode url="BB.aspx" title="ManagerMenu2"></siteMapNode>
<siteMapNode url="CC.aspx" title="ManagerMenu3"></siteMapNode>
</siteMapNode>
<siteMapNode url="Employee" title="管理平台">
<siteMapNode url="DD.aspx" title="EmployeeMenu1"></siteMapNode>
<siteMapNode url="EE.aspx" title="EmployeeMenu2"></siteMapNode>
</siteMapNode>
<siteMapNode url="Accountant" title="管理平台">
<siteMapNode url="FF.aspx" title="AccountantMenu1"></siteMapNode>
<siteMapNode url="GG.aspx" title="AccountantMenu2"></siteMapNode>
</siteMapNode>
</siteMapNode>
</siteMap>
Default.aspx:
复制内容到剪贴板
程序代码
<%@ Page Language="C#" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<script runat="server">
protected void Page_Load(object sender, EventArgs e)
{
//ManagerMenu
SiteMapDataSource1.StartingNodeUrl = "Manager";
//EmployeeMenu
SiteMapDataSource2.StartingNodeUrl = "Employee";
//AccountantMenu
SiteMapDataSource3.StartingNodeUrl = "Accountant";
}
</script>
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title>TreeView示例 -Mzwu.Com</title>
</head>
<body>
<form id="form1" runat="server">
<div>
ManagerMenu:
<asp:SiteMapDataSource ID="SiteMapDataSource1" runat="server" />
<asp:TreeView ID="TreeView1" runat="server" DataSourceID="SiteMapDataSource1"
ExpandDepth="1" ShowLines="True">
</asp:TreeView>
<br />
EmployeeMenu:
<asp:SiteMapDataSource ID="SiteMapDataSource2" runat="server" />
<asp:TreeView ID="TreeView2" runat="server" DataSourceID="SiteMapDataSource2"
ExpandDepth="1" ShowLines="True">
</asp:TreeView>
<br />
AccountantMenu:
<asp:SiteMapDataSource ID="SiteMapDataSource3" runat="server" />
<asp:TreeView ID="TreeView3" runat="server" DataSourceID="SiteMapDataSource3"
ExpandDepth="1" ShowLines="True">
</asp:TreeView>
</div>
</form>
</body>
</html>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<script runat="server">
protected void Page_Load(object sender, EventArgs e)
{
//ManagerMenu
SiteMapDataSource1.StartingNodeUrl = "Manager";
//EmployeeMenu
SiteMapDataSource2.StartingNodeUrl = "Employee";
//AccountantMenu
SiteMapDataSource3.StartingNodeUrl = "Accountant";
}
</script>
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title>TreeView示例 -Mzwu.Com</title>
</head>
<body>
<form id="form1" runat="server">
<div>
ManagerMenu:
<asp:SiteMapDataSource ID="SiteMapDataSource1" runat="server" />
<asp:TreeView ID="TreeView1" runat="server" DataSourceID="SiteMapDataSource1"
ExpandDepth="1" ShowLines="True">
</asp:TreeView>
<br />
EmployeeMenu:
<asp:SiteMapDataSource ID="SiteMapDataSource2" runat="server" />
<asp:TreeView ID="TreeView2" runat="server" DataSourceID="SiteMapDataSource2"
ExpandDepth="1" ShowLines="True">
</asp:TreeView>
<br />
AccountantMenu:
<asp:SiteMapDataSource ID="SiteMapDataSource3" runat="server" />
<asp:TreeView ID="TreeView3" runat="server" DataSourceID="SiteMapDataSource3"
ExpandDepth="1" ShowLines="True">
</asp:TreeView>
</div>
</form>
</body>
</html>