ASP.NET MVC 利用分部视图基于不同的角色显示不同的菜单

在布局页面_Layout.cshtml中将菜单栏改写成分部视图

<div id="menucontainer">
    <ul id="menu">
        <li>@Html.ActionLink("Home", "Index", "Home")</li>
        <li>@Html.ActionLink("About", "About", "Home")</li>
    </ul>
</div>

改为

<div id="menucontainer">
    <ul id="menu">
        @{Html.RenderAction("你的菜单Action名字", "你的菜单Controller名字");}
    </ul>
</div>

其中@Html.RenderAction是通过Controller中的Action来调用用户控件,将Action对应的View当做Partial部分显示在调用处。

然后建立对应的菜单的Controller和Action。(你也可以先建立菜单Controller和Action)

呈现分部视图Html.RenderAction() 对应有控制器,Html.RenderPartial()直接指向视图。

@{Html.RenderAction(“action名字”, “controller名字”);}只能指向当前区域下的action

@{Html.RenderAction(“action名字”, “controller名字”, new { area = “Area名字” });}访问其他区域下的action

分别命名为TestMenuController和Menu。

在后台可根据用户名角色权限得到菜单集合

using System.Collections.Generic;
using System.Web.Mvc;

namespace test.Controllers
{
    public class TestMenuController : Controller
    {
        //
        // GET: /TestMenu/

        public ActionResult Menu()
        {
            List<Role> _testroles = new List<Role>();
            /*根据User.Instance.Name或者你登陆的时候将你的用户信息放入Session中,取出,然后根据用户, 获取你自己定义的role信息*/
          //将角色名称放入List<string>中
           List<string>  roles = new List<string>();
            return PartialView(roles);
        }
    }
}

在Menu.cshtml中加入如下代码

@model IEnumerable<string>
@{
    this.Layout = null;
}
<div class="pageSidebar">
    <ul class="nav nav-stacked nav-pills">
@if(Model.Count()>0&&Model.Contains("角色名称")){
     @foreach (var item in Model)
{
<li role="presentation">@Html.ActionLink("菜单名称", "action", "controller")</li>
}
}
</ul>
</div>
参考地址:https://www.cnblogs.com/tianzibobo/archive/2013/01/07/role_menu.html

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值