ASP.NET导航控件TreeView根据登录用户显示不同的菜单

通常,我们使用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>


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>



转自:http://www.mzwu.com/article.asp?id=2496

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值