1.数据库设计

  create database BookShop
go use bookshop
go --模块表
create table Module
(
ModuleID int not null primary key identity(1,1),
ModuleName varchar(50) not null unique,
ModuleIcon varchar(20) not null default '',
) -- 功能表 Menu
create table Menu
(
MenuID int not null primary key identity(1,1),
MenuName varchar(50) not null unique,
MenuIcon varchar(20) not null default '',
CtrlName varchar(50) not null, -- 对应的 控制器名称 BookController
ModuleID int not null foreign key references Module(ModuleID) --
) -- 方法函数表 Action
create table [Action]
(
ActionID int not null primary key identity(1,1),
ActionName varchar(50) not null unique,
ActionIcon varchar(20) not null default '',
ActName varchar(50) not null ,
MenuID int not null foreign key references Menu(MenuID) --
) create table [Role]
(
RoleID int not null primary key identity(1,1),
RoleName varchar(20) not null unique,
[Description] varchar(100) not null default '没描述'
) create table [User]
(
UserID int not null primary key identity(1,1),
LoginName varchar(20) not null unique, --登录名
UserName varchar(20) not null , --真实姓名
[Password] varchar(20) not null, ) create table UserRole --用户和角色的关系表
(
RoleID int not null foreign key references [Role](RoleID),
UserID int not null foreign key references [User](UserID)
) alter table UserRole
add constraint PK_UserRole primary key (RoleID,UserID) go create table RoleAction -- 角色 方法 关系表
(
RoleID int not null foreign key references [Role](RoleID),
ActionID int not null foreign key references [Action](ActionID)
) alter table RoleAction
add constraint PK_RoleAction primary key (RoleID,ActionID)

2.实体类

public class ModuleVM
{
public ModuleVM()
{
menuVms = new List<MenuVm>();
}
public string ID { get; set; }
public string Name { get; set; }
public List<MenuVm> menuVms { get; set; }
}
public class MenuVm
{
public MenuVm()
{
actions = new List<ActionVm>();
}
public int ID { get; set; }
public string Name { get; set; }
public string ctrName { get; set; }
public List<ActionVm> actions { get; set; }
}
public class ActionVm
{
public int ID { get; set; }
public string Name { get; set; } public string ActName { get; set; }
}

3.模板页面代码

@using PowerDemo.Models
@using Action= PowerDemo.Models.Action
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>@ViewBag.Title - 我的 ASP.NET 应用程序</title>
@Styles.Render("~/Content/css")
@Scripts.Render("~/bundles/modernizr")
</head>
<body>
<div class="navbar navbar-inverse navbar-fixed-top">
<div class="container">
<div class="navbar-header">
<button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-collapse">
<span class="icon-bar"></span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
</button>
@Html.ActionLink("应用程序名称", "Index", "Home", new { area = "" }, new { @class = "navbar-brand" })
</div>
<div class="navbar-collapse collapse">
<ul class="nav navbar-nav">
<li>@Html.ActionLink("主页", "Index", "Home")</li>
<li>@Html.ActionLink("关于", "About", "Home")</li>
<li>@Html.ActionLink("联系方式", "Contact", "Home")</li>
</ul>
</div>
</div>
</div>
<div class="container body-content">
<div class="row">
<div class="col-md-3">
@{
User loginuser = Session["User"] as User;
BookShopEntities DB = new BookShopEntities();
List<ModuleVM> list = new List<ModuleVM>();
foreach (Role role in loginuser.Role)
{
foreach (Action action in role.Action)
{
MenuVm mvm = new MenuVm()
{
ID = action.Menu.MenuID,
Name = action.Menu.MenuName,
ctrName = action.Menu.CtrlName.Replace("Controller","")
};
ActionVm avm = new ActionVm()
{
ID = action.ActionID,
Name = action.ActionName,
ActName = action.ActName
};
mvm.actions.Add(avm);
ModuleVM module = list.FirstOrDefault(mo => mo.ID==action.Menu.Module.ModuleID.ToString());
if (module==null)
{
module = new ModuleVM()
{
ID = action.Menu.Module.ModuleID.ToString(),
Name = action.Menu.Module.ModuleName,
};
list.Add(module);
}
module.menuVms.Add(mvm);
}
}
}
<ul class="list-group">
@foreach (ModuleVM module in list)
{
<li class="list-group-item">
@module.Name
<ul class="list-group">
@foreach (MenuVm menu in module.menuVms)
{
<li class="list-group-item">
@menu.Name
<div class="list-group">
@foreach (ActionVm a in menu.actions)
{
<a class="list-group-item" href="/@menu.ctrName/@a.ActName">@a.Name</a>
}
</div>
</li>
}
</ul>
</li>
}
</ul>
</div>
<div class="col-md-12">@RenderBody()</div>
</div>
<hr />
<footer>
<p>&copy; @DateTime.Now.Year - 我的 ASP.NET 应用程序</p>
</footer>
</div> @Scripts.Render("~/bundles/jquery")
@Scripts.Render("~/bundles/bootstrap")
@RenderSection("scripts", required: false)
</body>
</html>

说一说MVC的MenuCard(五)的更多相关文章

  1. ASP.NET MVC Model验证(五)

    ASP.NET MVC Model验证(五) 前言 上篇主要讲解ModelValidatorProvider 和ModelValidator两种类型的自定义实现, 然而在MVC框架中还给我们提供了其它 ...

  2. ASP.NET MVC Model绑定(五)

    ASP.NET MVC Model绑定(五) 前言 前面的篇幅对于IValueProvider的获取位置和所处的生成过程做了讲解,本篇将会对IValueProvider的使用做个基础的示例讲解,读完本 ...

  3. ASP.NET MVC Model元数据(五)

    ASP.NET MVC Model元数据(五) 前言 在上一篇中我们描述了应用于Model上面的各种用于显示控制的特性类,在本篇中将详细的介绍这些特性类的应用,虽然它们跟Model元数据的直接关系并不 ...

  4. Mvc项目实例 MvcMusicStore 五

    Mvc项目实例 MvcMusicStore 一Mvc项目实例 MvcMusicStore 二Mvc项目实例 MvcMusicStore 三Mvc项目实例 MvcMusicStore 四Mvc项目实例 ...

  5. 2017.3.31 spring mvc教程(五)Action的单元测试

    学习的博客:http://elf8848.iteye.com/blog/875830/ 我项目中所用的版本:4.2.0.博客的时间比较早,11年的,学习的是Spring3 MVC.不知道版本上有没有变 ...

  6. ASP.NET MVC学习(五)之MVC原理解析

    ASP.NET MVC 请求生命周期 生命周期步骤概览 当我们对ASP.NET MVC网站发出一个请求的时候,会发生5个主要步骤: 步骤1:创建RouteTable 当ASP.NET应用程序第一次启动 ...

  7. ASP.NET MVC学习---(五)MVC初体验

    经过之前n多的铺垫 我们已经大概了解了这个姓m名vc的家伙了 那么今天我们就来体验一把 怎么体验呢? 就来做一个小例子吧~ mvc增删改查的例子 数据库还是之前我们的老朋友 关系图: 表中的数据已填好 ...

  8. MVC系列学习(十五)-验证码

    1.方式一: public class VCode { /// <summary> /// 生成验证码图片 字节数组 /// </summary> /// <return ...

  9. Spring MVC学习(五)---ModelAndView没有明显申明name

    看图不解释: 对于这种写法: new ModelAndView().addObject(XXX)  

随机推荐

  1. Linux多线程编程,为什么要使用线程,使用线程的理由和优点等

    线程?为什么有了进程还需要线程呢,他们有什么区别?使用线程有什么优势呢?还有多线程编程的一些细节问题,(http://www.0830120.com)如线程之间怎样同步.互斥,这些东西将在本文中介绍. ...

  2. Android进阶:六、在子线程中直接使用 Toast 及其原理

    一般我们都把Toast当做一个UI控件在主线程显示.但是有时候非想在子线程中显示Toast,就会使用Handler切换到主线程显示. 但是子线程中真的不能直接显示Toast吗? 答案是:当然可以. 那 ...

  3. 微软官网tools

    DHCP/AD域插件: 远程管理工具(含DHCP/AD域) 安装网址: https://www.microsoft.com/zh-cn/download/details.aspx?id=7887 程序 ...

  4. DBUtils - Python数据库连接池

    flask没有ORM操作这一功能, 但是想要操作数据库怎么办呢, 使用第三方包DBUtils 查询需要SQL原生语句! DBUtils 第一步还是要下载 使用pycharm直接搜索DBUtils fr ...

  5. look back to 2018

    只写展望怎么行,还是缺一篇总结.2018年几乎没有怎么发朋友圈,需要一些文字记录一下这一年发生的事. 去年的现在,2018年的开端,结束了研一上学期充实的生活,下学期一项艰巨的任务就是完成大项目,一个 ...

  6. USACO 邮票 Stamps

    f[x]表示组成 x 最少需要的邮票数量 一一举例 最多贴5张邮票,有三种邮票可用,分别是1分,3分,8分 组成0分需要0张邮票 ——f[0]=0 组成1分需要在0分的基础上加上一张1分邮票 ——f[ ...

  7. Oracle、DB2、SQLSERVER、Mysql、Access分页SQL语句

    最近把平时在项目中常用到的数据库分页sql总结了下.大家可以贴出分页更高效的sql语句.sqlserver分页  第一种分页方法 需用到的参数:  pageSize 每页显示多少条数据  pageNu ...

  8. springmvc是如何工作的

    上图便是springmvc的工作流程,看着条条框框的,其实说的直白一点,springmvc就是负责处理用户的需求(request/url),它的负责人(核心组件)就是前端控制器(DispatcherS ...

  9. VS中自定义类模版

    以下为vs2017 专业版,安装目录在D盘 安装路径: D:\Program Files (x86)\Microsoft Visual Studio\\Professional\Common7\IDE ...

  10. Vue(三十二)SSR服务端渲染Nuxt.js

    初始化Nuxt.js项目步骤 1.使用脚手架工具 create-nuxt-app 创建Nuxt项目 使用yarn或者npm $ yarn create nuxt-app <项目名> 注:根 ...