ASP.NET MVC3.0 入门指南 5 从控制器访问模型数据
2011-05-10 16:00 Bingo Lee 阅读(4833) 评论(12) 编辑 收藏 举报
从控制器访问模型数据
本节,您将创建一个新的MoviesController类并编写代码读取电影数据
并用视图模板在浏览器中显示他们。在继续前,请确保您的应用程序被编
译。
右键Controllers文件夹新建一个MoviesController控制器。选择下面的
选项:
- Controller name: MoviesController. (默认. )
- Template: Controller with read/write actions and views, using Entity Framework.
- Model class: Movie (MvcMovie.Models).
- Data context class: MovieDBContext (MvcMovie.Models).
- Views: Razor (CSHTML). (默认.)
单击“Add”。Visual Studio创建了下面的文件夹和文件:
- 在项目的Controller文件夹下MoviesController.cs文件
- 在项目的View文件夹下Movies文件夹
- 在新创建的文件夹Views\Movies下Create.cshtml, Delete.cshtml,
Details.cshtml, Edit.cshtml, and Index.cshtml。
ASP.NET MVC 3架构机制自动创建CRUD(create, read, update, and delete)
响应方法和视图。您现在拥有了全部的web应用程序的功能,支持增加、显示、
编辑、删除电影作品。
运行应用程序并通过在浏览器地址栏中URL后追加/Movies来浏览Movies控制器。
因为应用程序依托默认的路由(在Global.asax文件中定义),浏览请求
http://localhost:xxxxx/Movies被路由到Movies控制器的默认方法Index。
换句话说,http://localhost:xxxxx/Movies实际上和http://localhost:xxxxx/Movies/Index
是一样的。因为您还没有添加任何东西,所以电影列表是空的。
创建电影
选择“Create New”链接。输入一个电影的详细信息然后单击“Create”按钮。
单击“Create”按钮使页面回发到服务器端(那里的电影信息
保存在数据库中)。您别重定向到/Movies URL,在列表里您
能看到刚被添加的电影信息。
创建一些电影作品,测试全部的功能,编辑、明细、删除。
审视代码
打开Controllers\MoviesController.cs文件并审视生成的Index方法
代码。部分控制器Index方法的代码如下所示:
public class MoviesController : Controller { private MovieDBContext db = new MovieDBContext(); // // GET: /Movies/ public ViewResult Index() { return View(db.Movies.ToList()); } }
如前面所述,下面的行在MoviesController类中实例化了一个电影
数据库的内容。
private MovieDBContext db = new MovieDBContext();
Movies控制器返回数据库中的所有电影资料实体并把结果传递给Index
视图。
强类型模型和@model关键字
在教程的前面部分,您了解了如何使用ViewBag对象把数据通过控制器
传递给视图。ViewBag是一个动态对象,提供了方便的迟绑定方式将信
息传递给视图。
ASP.NET MVC也支持传递强类型数据给视图模板。这种强类型的方式支
持编译时检查代码和丰富的智能感知。我们将在MoviesController类
和Index.cshtml视图模板中
采用这种方式。
请注意该代码创建一个List对象时调用Index方法中View助手方法。代码
通过控制器传递电影列表给视图:
public ViewResult Index() { return View(db.Movies.ToList()); }
通过在视图模板文件的顶部包含@model表达式,您可以指定在视图中
您期望使用的对象类型。当您创建电影控制器的时候,Visual Studio自
动在视图模板文件Index.cshtml的顶部包含@model表达式:
@model IEnumerable.Models.Movie
@model指令允许您访问由控制器使用强类型Model对象传递给
视图的电影列表。比如,Index.cshtml模板,代码通过foreach表
达式遍历了基于强类型的电影资料。
@foreach (var item in Model) { @Html.DisplayFor(modelItem => item.Title) @Html.DisplayFor(modelItem => item.ReleaseDate) @Html.DisplayFor(modelItem => item.Genre) @Html.DisplayFor(modelItem => item.Price) @Html.ActionLink("Edit", "Edit", new { id=item.ID }) | @Html.ActionLink("Details", "Details", new { id=item.ID }) | @Html.ActionLink("Delete", "Delete", new { id=item.ID }) }
由于实体对象是强类型(被用作可枚举对象),循环中的每个item对象
都是强类型的Movie。其他好处指的是编译时检查代码和全部的智能感知
支持。
使用SQL SERVER精简版
实体框架代码优先(Entity Framework Code First)检测到数据库连接字符串
指向Movies数据库的不存在,所以代码优先自动创建数据库。您可以通过查看
App_Data文件夹来验证它被创建。如果您没有看到Movies.sdf文件,在解决方案
资源管理器的工具栏中单击显示“所有文件”按钮,单击“刷新”按钮,然后展开
App_Data文件夹。
双击Movies.sdf文件打开服务器资源管理器。然后展开Table文件夹,
您可以看到被创建的表。
注意:如果您双击Movies.sdf文件时报错,请确保您已经安装了
SQLServer Compact 4.0(运行时+工具支持)。如果您现在安装,您
不得不关闭在重新打开visual studio。
有两个表,一个对应Movie实体集,(EdmMetadata)一个用来存储实体和
数据库之间映射关系的对应版本。EdmMetadata表被用来检测实体和数据库
是否同步。
右键Movies表,选择编辑表结构。
注意Movies表结构和Movie类对应。实体框架代码优先(Entity Framework Code First)
依据Movie类自动创建这个结构。
完成时,关闭链接。(如果不关闭链接,您下次运行这个项目的时候可能会得到一个错误)
您现在拥有了数据库并通过简单的列表展现了他们。在下一节里,我们将审视剩下的
代码并增加一个SearchIndex查找方法和一个SearchIndex视图允许您查找数据
库中的电影资料。
下一节:Asp.net MVC3.0 入门指南 6 审视编辑方法和视图
原文网址:http://www.asp.net/mvc/tutorials/getting-started-with-mvc3-part5-cs