在布局页面_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