ASP.NET MVC 3 Model【通过一简单实例一步一步的介绍】
今天主要讲Model的两个方面: 1. ASP.Net MVC 3 Model 简介 通过一简单的事例一步一步的介绍 2. ASP.Net MVC 3 Model 的一些验证
MVC 中 Model 主要负责维持数据状态,将数据从数据存储器中检索并传递给控制器,客户端传送过来的数据通过处理后再传回数据存储系统中。是MVC中较为重要的一层。 这里为什么说是数据存储器而不是数据库,我们以前经常说的就是重数据库中增删改查数据等等什么的,但是 MVC 的Model 不单单只能在数据库中操作数据也能通过其他方式操作数据。学过java的ssh三大框架的人都应该知道hibernate 框架吧!java 中的hibernate框架就是ORM的典型应用!咱们.net 平台也有些访问数据库的框架比如说ling to sql Entity Framework NHibernate 等。所以说呢不是操作数据库而是操作数据存储器。
下面用一个简单的事例演示一下 本实例用list模拟一些person类的对象然后再view 层中显示出来。
1. 首先先在Model层中新建一个Person 类。


1 namespace Mvc3App1.Models
2 {
3 public class Person
4 {
5 public string IdCard { get; set; }
6 public string Name { get; set; }
7 public string Sex { get; set; }
8 public int Age { get; set; }
9 }
10 }

此Person类简单了定义了几个属性。注意第一行的命名空间Mvc3App1.Models 一会在Controller 中会用到。 2. 新建一个Controller 在这我就不截图了因为前面有一篇专讲Contoller 的文章不了解Controller 的请您先看下Controller的文章 ASP.Net MVC 3 Controller 2.1 首先如果在Controller中用Model层中的实体类首先必须引入命名空间
using Mvc3App1.Models;
2.2 在Index() 这个Action 方法中定义一个List 集合 然后给它初始化几个对象。

1 public ActionResult Index()
2 {
3 //新建一个泛型集合然后给他初始化一些数据
4 List<Person> persons = new List<Person>
5 {
6 new Person { IdCard = "001", Name = "张三", Age = 21, Sex = "男"},
7 new Person { IdCard = "002", Name = "李四", Age = 21, Sex = "男"},
8 new Person { IdCard = "003", Name = "王麻子", Age = 21, Sex = "男"},
9 new Person { IdCard = "004", Name = "赵六", Age = 21, Sex = "男"},
10 };
11 return View(persons);
12 }

2.3 添加一个View


ok 到此为止,View - Controller - Model 都已经创建完毕,下面咱接着看View层的结构。

1 @model Mvc3App1.Models.Person
2
3 @{
4 ViewBag.Title = "Index";
5 }
6
7 <h2>Index</h2>

看第一行,就是将Action 返回的结果存到model中但是,咱返回的是一个List集合那怎么办呢?好办用集合接收不就完事了,再这提醒您一句如果您看不懂@符号是干什么使的,我建议您先看一下我前面讲 Razor 视图的两篇文章 ASP.NET MVC 3 Razor 视图引擎 基本语法 ASP.NET MVC 3 Razor 视图引擎 布局 好下面咱就先解决第一个问题怎么用集合接受
@model IEnumerable<Mvc3App1.Models.Person>
用IEnumerable接收就 ok 了,有人问它是什么东东,告诉您 公开枚举器,该枚举器支持在指定类型的集合上进行简单迭代 List ArrayList 等 就实现的该接口。

1 @model IEnumerable<Mvc3App1.Models.Person>
2 @using Mvc3App1.Models;
3
4 @{
5 ViewBag.Title = "Index";
6 }
7
8 <h2>人员信息表</h2>
9 <ul>
10 <li style = "list-style-type:none; font-weight:bold">编号-姓名</li>
11 @* 这里Person用var关键字也行,嘿嘿 用.net2.0 习惯了 *@
12 @foreach (Person person in Model)
13 {
14 <li>@person.IdCard-@person.Name</li>
15 }
16 </ul>

12 - 14 行 foreach 遍历输出 写着这么多了先看下运行结果吧!

数据返回到View层了,那么View层怎么将参数传给Controller 好下面咱再添加一个Detaile 用于显示详情的Action

1 public class MTestController : Controller
2 {
3 //新建一个泛型集合然后给他初始化一些数据
4 private List<Person> persons = new List<Person>
5 {
6 new Person { IdCard = "001", Name = "张三", Age = 21, Sex = "男"},
7 new Person { IdCard = "002", Name = "李四", Age = 21, Sex = "男"},
8 new Person { IdCard = "003", Name = "王麻子", Age = 21, Sex = "男"},
9 new Person { IdCard = "004", Name = "赵六", Age = 21, Sex = "男"},
10 };
11 public ActionResult Index()
12 {
13 return View(persons);
14 }
15
16 public ActionResult Detaile(string id)
17 {
18 Person person = persons.Find(p=>p.IdCard == id);
19 return View(person);
20 }
21
22 }

为了数据共享将4-9行虚拟的数据提到方法外面去,Detaile方法接受一个id参数,为了不再修改路由就可以直接运行这里就用id代表IdCard。然后调用List集合中的find方法查询。 再看一下Detaile 的View 层是怎么写的吧!

@model Mvc3App1.Models.Person
@{
ViewBag.Title = "Detaile";
}
<h2>详细信息</h2>
编号:@Model.IdCard 姓名:@Model.Name 性别:@Model.Sex 年龄:@Model.Age

很简单不再做额外的解释,好下一步改写Index 的View层代码 将foreach中的语句改为
<li>@person.IdCard-@Html.ActionLink(person.Name,"Detaile",new {id=person.IdCard})</li>
简单说就是给姓名文本加一个a标签 (超链接)但是这个标签和以前的有点不同,这就是MVC 为了简化代码,出的HTML helper 但是今天的主角不是它,我简单的说先上面这行语句就行了 Html.ActionLink 从英语单词上不难理解它就代表一个超链接,其中第一个参数是超链接的文本- 第二个参数的转向那个Action 及 Action 的名字,第三个是传的参数。
看下运行结果吧!
Index

Detaile

由于时间关系今天就写到这了,关于Model的验证方面的知识我会尽快补上,晚安!!!!
------------------------------------------------------------- 感谢您看完本篇博文!!!!
互联网产品永远是Beta版,没有做不到的只有想不到的。 李亮和大家共同学习共同进步,如有什么疑问或博文有什么错误知识,请您斧正。 您可以给我发邮件,也可以再文章下面留言我会第一时间回复您。
再次感谢您的观看,祝您身体健康!工作顺利!
ASP.NET MVC 3 Model【通过一简单实例一步一步的介绍】的更多相关文章
- ASP.NET MVC 之Model的呈现
ASP.NET MVC 之Model的呈现(仅此一文系列三) 本文目的 我们来看一个小例子,在一个ASP.NET MVC项目中创建一个控制器Home,只有一个Index: public class H ...
- Asp.Net MVC+BootStrap+EF6.0实现简单的用户角色权限管理
这是本人第一次写,写的不好的地方还忘包含.写这个的主要原因是想通过这个来学习下EF的CodeFirst模式,本来也想用AngularJs来玩玩的,但是自己只会普通的绑定,对指令这些不是很熟悉,所以就基 ...
- Asp.net MVC的Model Binder工作流程以及扩展方法(2) - Binder Attribute
上篇文章中分析了Custom Binder的弊端: 由于Custom Binder是和具体的类型相关,比如指定类型A由我们的Custom Binder解析,那么导致系统运行中的所有Action的访问参 ...
- Asp.net MVC的Model Binder工作流程以及扩展方法(1) - Custom Model Binder
在Asp.net MVC中, Model Binder是生命周期中的一个非常重要的部分.搞清楚Model Binder的流程,能够帮助理解Model Binder的背后发生了什么.同时该系列文章会列举 ...
- ASP.NET MVC 4 插件化架构简单实现-思路篇
用过和做过插件的都会了解插件的好处,园子里也有很多和讨论,但大都只些简单的加载程序集什么的,这里主要讨论的就是使用 ASP.NET MVC 4 来实现每个插件都可以完全从主站点剥离出来,即使只是一个插 ...
- ASP.NET MVC 4 插件化架构简单实现-实例篇
先回顾一下上篇决定的做法: 1.定义程序集搜索目录(临时目录). 2.将要使用的各种程序集(插件)复制到该目录. 3.加载临时目录中的程序集. 4.定义模板引擎的搜索路径. 5.在模板引擎的查找页面方 ...
- [转]ASP.NET MVC 2: Model Validation
本文转自:http://weblogs.asp.net/scottgu/archive/2010/01/15/asp-net-mvc-2-model-validation.aspx?CommentPo ...
- Asp.net MVC的Model Binder工作流程以及扩展方法(1)
Asp.net MVC的Model Binder工作流程以及扩展方法(1)2014-03-19 08:02 by JustRun, 523 阅读, 4 评论, 收藏, 编辑 在Asp.net MVC中 ...
- 区别:ASP.NET MVC的Model、DTO、Command
最近在用CQRS架构模式做项目,有些感悟,记录下来. 问题的描述(大家是否也存在过类似的情况呢?): 从刚开始时项目中没有区分这3种对象,所以导致了很多职责公用,然后就乱了,比如Command一部分职 ...
随机推荐
- 【转】block一点也不神秘————如何利用block进行回调
我们在开发中常常会用到函数回调,你可以用通知来替代回调,但是大多数时候回调是比通知方便的,所以何乐而不为呢?如果你不知道回调使用的场景,我们来假设一下: 1.我现在玩手机 2.突然手机没有电了 3.我 ...
- NSString截取字符串
NSString 是经常会用到的,很多时候需要对字符串进行一些处理,本文简单介绍字符串截取操作: 比如: 1.定义一个字符串a, 截取a的某一个部分(子串) NSString *a = @" ...
- xcode升级插件失效修复
每次xcode升级以后,插件都会失效.可以通过一行命令解决这个问题. 摘自传人的博客 find ~/Library/Application\ Support/Developer/Shared/Xcod ...
- eclipse/myeclipse 变量名自动补全问题
原理是:在输入变量名后,去掉按下空格或=后,代码上屏 以前只知道alt+/调出assist,后来发现可以所有字母都激活content assist(8.1里有写).用起来果然很爽,但是eclipse ...
- 高级I/O函数(3)-tee、fcntl函数
tee函数使用 功能描述:tee函数在两个管道文件描述符之间复制数据,也是零拷贝操作.它不消耗数据,因此源文件描述符仍然可以用于后续的操作. 函数原型: #include <fcntl.h> ...
- Centos7下Intel与AMD双显卡驱动的安装
前2天,在Nvidia单显卡上成功安装上了NVIdia的驱动,一时兴起,拿出另外的一个HP笔记本也准备装上驱动,悲催的是HP的显卡是AMD的,更加.更加悲催的是还是Intel+AMD的双显卡.网络 ...
- 50个jQuery代码段帮你成为更好的JavaScript开发者
1. 如何创建嵌套的过滤器: 允许你减少集合中的匹配元素的过滤器,只剩下那些与给定的选择器匹配的部分.在这种情况下,查询删除了任何没(:not)有(:has)包含class为“selected”(.s ...
- 面向对象设计模式之TemplateMethod模板方法(行为型)
动机:在软件构建过程中,对于某一项任务,他常常有稳定的整体操作结构,但各个子步骤却有很多改变的需求,或者由于固有的原因(比如框架与应用之间的关系)而无法和任务的整体结构同时实现:如何在确定稳定操作结构 ...
- javescript扩展方法
<script type="text/javascript"> //扩展方法 '原型'->'prototype' //通过类对像的prototype设置扩展方法 ...
- JS form表单提交的方法
1.当输入用户名和密码为空的时候,需要判断.这时候就用到了校验用户名和密码,这个需要在jsp的前端页面写:有两种方法,一种是用submit提交.一种是用button提交.方法一: 在jsp的前端页面的 ...