admin 管理员组文章数量: 887021
2024年1月12日发(作者:网页设计基础教程)
MVC 编程模型
MVC 是三个 开发模型之一。
MVC 是用于构建 web 应用程序的一种框架,使用 MVC (Model View Controller) 设计:
Model(模型)表示应用程序核心(比如数据库记录列表)
View(视图)对数据(数据库记录)进行显示
Controller(控制器)处理输入(写入数据库记录)
MVC 模型同时提供对 HTML、CSS 以及 JavaScript 的完整控制。
MVC 模型通过三个逻辑层来定义 web 应用程序:
business layer(业务层、模型逻辑)
display layer(显示层、视图逻辑)
input control(输入控件、控制器逻辑)
模型(Model)
模型(Model)是应用程序中用于处理应用程序数据逻辑的部分。
通常模型对象在数据库中存取数据。
View(视图)
View(视图)是应用程序中处理数据显示的部分。
通常从模型数据中创建视图。
控制器
控制器是应用程序中处理用户交互的部分。
通常控制器从视图读取数据、控制用户输入,并向模型发送数据数据。
MVC 的这种拆分有助于我们管理复杂的应用程序,因为您能够在同一时间关注一个方面。例如,您可以在不依赖业务逻辑的情况下对视图进行设计。同时对应用程序的设计也更加容易。
MVC 的这种拆分同时也简化了分组开发。不同的开发人员可同时开发视图、控制器逻辑和业务逻辑。
Web Forms vs MVC
MVC 编程模型是与传统的 (Web Forms) 相比更轻量级的替代方案。它是轻量级的高可测试性的框架,同时整合了所有已有的 特性,比如模板页、安全性和认证。
Visual Studio Express 2012/2010
Visual Studio Express 是 Microsoft Visual Studio 的免费版本。
Visual Studio Express 是为 MVC (以及 Web Forms)量身定制的开发工具。
Visual Studio Express 包含:
MVC 和 Web Forms
拖拽 web 控件和 web 组件
web 服务器语言(Razor 使用 VB 和 C#)
web 服务器 (IIS Express)
数据库服务器 (SQL Server Compact)
完整的 web 开发框架 ()
如果您已经安装了 Visual Studio Express,您将从本教程获得更多益处。
如果您希望安装 Visual Studio Express,请点击以下链接:
Visual Web Developer 2012(Windows 7 或 Windows 8)
Visual Web Developer 2010(Windows Vista 或 XP)
在首次安装 Visual Studio Express 之后,它会再次运行安装程序,来安装补丁和服务包。请再次点击链接。
为了学习 MVC,我们将构建一个 Internet 应用程序。
部分 1:创建应用程序
我们将构建什么
我们将构建一个 Internet 应用程序,它支持添加、编辑、删除以及列出数据库中的信息。
我们将做什么
Visual Web Developer 提供了构建 web 应用程序的不同模板。
我们将使用 Visual Web Developer 来创建使用 HTML5 标记的空白 MVC Internet 应用程序。
当这个空白的 Internet 应用程序被创建之后,我们将逐步向该应用添加代码,直到彻底完成。我们将使用 C# 作为编程语言,以及最新的 Razor 服务器代码标记。
沿着这个路径,我们将讲解该应用程序的内容、代码和所有组件。
创建 web 应用程序
如果您已安装 Visual Web Developer,请启动 Visual Web Developer 并选择新项目。否则您只能通过阅读教程来学习了。
在新建项目对话框中:
打开 Visual C# 模板
选取模板 MVC 3 Web 应用程序
把项目名称设置为 MvcDemo
设置磁盘位置,比如 c:w3school_demo
点击确定
当新项目对话框打开时:
选择 Internet Application 模板
选择 Razor 引擎
选择 HTML5 标记
点击确定
Visual Studio Express 会创建类似这样的一个项目:
我们将在本教程的下一章中搞清楚文件和文件夹的内容。
为了学习 MVC,我们将构建一个 Internet 应用程序。
部分 2:了解应用程序文件夹。
MVC 文件夹
典型的 MVC web 应用程序拥有如下文件夹内容:
应用程序信息
Properties
引用
应用程序文件夹
App_Data 文件夹
Content 文件夹
Controllers 文件夹
Models 文件夹
Scripts 文件夹
Views 文件夹
配置文件
所有 MVC 应用程序中的文件夹名称都是相等的。MVC 框架基于默认的命名。控制器位于 Controllers
文件夹,视图位于 Views 文件夹,模型位于 Models 文件夹。您不必在应用程序代码中使用文件夹名称。
标准化的命名减少了代码量,同时有利于开发者对 MVC 项目的理解。
下面是对每个文件夹内容的简要描述:
App_Data 文件夹
App_Data 文件夹用于存储应用程序数据。
我们将在本教程稍后的章节向 App_Data 文件夹添加 SQL 数据库。
Content 文件夹
Content 文件夹用于静态文件,比如样式表(CSS 文件)、图表和图像。
Visual Web Developer 会自动向 Content 文件夹添加一个 themes 文件夹。这个 themes 文件夹存放 jQuery 样式和图片。在这个项目中,您可以删除这个主题文件夹。
Visual Web Developer 同时向项目添加标准的样式表文件:Content 文件夹中的文件 。这个样式表文件是您希望改变应用程序样式时需要编辑的文件。
我们将在本教程的下一章中编辑这个样式表文件 ()。
Controllers 文件夹
Controllers 文件夹包含负责处理用户输入和响应的控制器类。
MVC 要求所有控制器文件的名称以 "Controller" 结尾。
Visual Web Developer 已创建好一个 Home 控制器(用于首页和关于页面)以及一个 Account 控制器(用于登录页面):
我们将在本教程稍后的章节创建更多控制器。
Models 文件夹
Models 文件夹包含表示应用程序模型的类。模型存有并操作应用程序的数据。
我们将在本教程稍后的章节创建模型(类)。
Views 文件夹
Views 文件夹存有与应用程序的显示相关的 HTML 文件(用户界面)。
Views 文件夹中含有每个控制器对于的一个文件夹。
Visual Web Developer 已创建了一个 Account 文件夹、一个 Home 文件夹、一个 Shared 文件夹(在 Views 文件夹内)。
Account 文件夹包含用于注册并登录用户帐户的页面。
Home 文件夹用于存储诸如首页和关于页之类的应用程序页面。
Shared 文件夹用于存储控制器间分享的视图(模板页和布局页)。
我们将在本教程的下一章编辑这些布局文件。
Scripts 文件夹
Scripts 文件夹存储应用程序的 JavaScript 文件。
默认地,Visual Web Developer 在这个文件夹中放置标准的 MVC、Ajax 以及 jQuery 文件:
注释:文件 "modernizr" 是用于在应用程序中支持 HTML5 和 CSS3 的 JavaScript 文件。
为了学习 MVC,我们将构建一个 Internet 应用程序。
部分 3:添加样式和统一的外观(布局)。
添加布局
文件 _ 表示应用程序中每个页面的布局。它位于 Views 文件夹中的 Shared 文件夹。
打开这个文件,把其内容替换为:
rel="stylesheet" type="text/css" />
@RenderBody()
Copyright W3schools 2012. All Rights Reserved.
HTML 帮助器
在上面的代码中,HTML 帮助器用于修改 HTML 输出:
@t() - URL 内容在此处插入。
@Link() - HTML 链接在此处插入。
我们将在本教程稍后的章节讲解 HTML 帮助器。
Razor 语法
在上面的代码中,由红色标记的代码是使用 Razor 标记的 C#。
@ - 在此处插入页面标题。
@RenderBody() - 此处呈现页面内容。
您可以在我们的 Razor 教程中学习 C# 和 VB (Visual Basic) 编写的 Razor 标记。
添加样式
应用程序的样式表是 。它位于 Content 文件夹中。
打开文件 ,并把其内容替换为:
body
{
font: "Trebuchet MS", Verdana, sans-serif;
background-color: #5c87b2;
color: #696969;
}
h1
{
border-bottom: 3px solid #cc9900;
font: Georgia, serif;
color: #996600;
}
#main
{
padding: 20px;
background-color: #ffffff;
border-radius: 0 4px 4px 4px;
}
a
{
color: #034af3;
}
/* 菜单样式 ------------------------------*/
ul#menu
{
padding: 0px;
position: relative;
margin: 0;
}
ul#menu li
{
display: inline;
}
ul#menu li a
{
background-color: #e8eef4;
padding: 10px 20px;
text-decoration: none;
line-height: 2.8em;
/*CSS3 properties*/
border-radius: 4px 4px 0 0;
}
ul#menu li a:hover
{
background-color: #ffffff;
}
/* 表单样式 ------------------------------*/
fieldset
{
padding-left: 12px;
}
fieldset label
{
display: block;
padding: 4px;
}
input[type="text"], input[type="password"]
{
width: 300px;
}
input[type="submit"]
{
padding: 4px;
}
/* 数据样式 ------------------------------*/
{
background-color:#ffffff;
border:1px solid #c3c3c3;
border-collapse:collapse;
width:100%;
}
th
{
background-color:#e8eef4;
border:1px solid #c3c3c3;
padding:3px;
}
td
{
border:1px solid #c3c3c3;
padding:3px;
}
_ViewStart 文件
Shared 文件夹(位于 Views 文件夹内)中的 _ViewStart 文件包含以下内容:
@{Layout = "~/Views/Shared/_";}
这段代码被自动添加到由应用程序显示的所有视图。
如果删除该文件,则必须向所有视图添加这段代码。
您将在本教程稍后的章节学到更多有关视图的知识。
为了学习 MVC,我们将构建一个 Internet 应用程序。
部分 4:添加控制器。
Controllers 文件夹
Controllers 文件夹包含负责处理用户输入和响应的控制器类。
MVC 要求所有控制器的名称必须以 "Controller" 结尾。
在我们的例子中,Visual Web Developer 已创建以下文件:(用于首页和关于页面)和 (用于登录页面):
web 服务器通常会将进入的 URL 请求直接映射到服务器上的磁盘文件。例如:某个 URL 请求(比如
"/")将映射到服务器根目录上的文件 ""。
MVC 框架的映射方式有所不同。MVC 将 URL 映射到方法。这些方法在类中被称为“控制器”。
控制器负责处理进入的请求、处理输入、保存数据、并把响应发送回客户端。
Home 控制器
我们应用程序中的控制器文件 ,定义了两个控件 Index 和 About。
把 文件的内容替换为:
using System;
using c;
using ;
using ;
using ;
namespace llers
{
public class HomeController : Controller
{
public ActionResult Index()
{return View();}
public ActionResult About()
{return View();}
}
}
Controller 视图
Views 文件夹中的文件 和 定义了控制器中的 ActionResult 视图
Index() 和 About()。
为了学习 MVC,我们将构建一个 Internet 应用程序。
部分 5:添加用于显示应用程序的视图。
Views 文件夹
Views 文件夹存储的是与应用程序显示(用户界面)相关的文件(HTML 文件)。根据语言的不同,这些文件的扩展名可能是 html、asp、aspx、cshtml 以及 vbhtml。
Views 文件夹包含每个控制器对应的一个文件夹。
Visual Web Developer 已创建了一个 Account 文件夹、一个 Home 文件夹、一个 Shared 文件夹(在 Views 文件夹内)。
Account 文件夹包含用于注册并登录用户帐户的页面。
Home 文件夹用于存储诸如首页和关于页之类的应用程序页面。
Shared 文件夹用于存储控制器间分享的视图(模板页和布局页)。
文件类型
能够在 Views 文件夹中找到以下 HTML 文件类型:
文件类型 扩展名
纯 HTML
.htm or .html
经典 ASP
.asp
经典
.aspx
Razor C#
Razor VB
.cshtml
.vbhtml
Index 文件
文件 表示应用程序的首页。它是应用程序的默认文件(首页文件)。
在文件中写入以下内容:
@{ = "Home Page";}
Welcome to W3School
Put Home Page content here
About 文件
文件 表示应用程序的关于页面。
在文件中写入以下内容:
@{ = "About Us";}
About Us
Put About Us content here
运行应用程序
选择调试,从调试菜单中启动调试(或者按 F5)。
您的应用程序将类似这样:
请点击“首页”和“关于”,看看它是如何运行的。
祝贺你
祝贺您。您已经创建好了第一个 MVC 应用程序。
注释:“电影”选项卡仍然无法点击。我们将在本教程稍后的章节中为“电影”选项卡添加代码。
为了学习 MVC,我们将构建一个 Internet 应用程序。
部分 6:添加数据库。
创建数据库
Visual Web Developer 带有免费的 SQL 数据库,名为 SQL Server Compact。
本教程所需的这个数据库能够通过以下几个简单的步骤来创建:
1. 右键点击解决方案资源管理器中的 App_Data 文件夹
2. 选择添加,新项目
3. 选择 SQL Server Compact Local Database *
4. 把这个数据库命名为
5. 点击添加按钮
* 如果选项中没有 SQL Server Compact Local Database,则表示您尚未在计算机上安装 SQL
Server Compact。请通过以下链接安装:SQL Server Compact
Visual Web Developer 会自动在 App_Data 文件夹中创建该数据库。
注释:在教程中,需要您掌握 SQL 数据库的基础知识。如果您希望首先学习这个主题,请访问我们的 SQL
教程。
添加数据库表
双击 App_Data 文件夹中的 将打开 Database Explorer window。
如需在这个数据库中创建新表,请右键点击 Tables 文件夹,然后选择创建表。
创建如下的列:
列
ID
Title
Director
Date
类型
int (primary key)
nvarchar(100)
nvarchar(100)
datetime
允许 Nulls
No
No
No
No
对列的解释:
ID 是用于识别表中每条记录的整数。
Title 是 100 个字符长度的文本列,用于存储影片的名称。
Director 是 100 个字符长度的文本列,用于存储导演的名字。
Date 是日期列,用于存储影片的发行日期。
在建好上述列之后,您必须把 ID 列设置为表的主键(记录识别符)。要做到这一点,请在列名(ID)上点击并在 Column Properties window 中选择 Primary Key,把 Identity 属性设置为 True。
当您完成创建表列后,请保存表并命名为 MovieDBs。
注释:我们已经把这个表命名为 "MovieDBs" (以 s 结尾)。在下一章,我们会看到 "MovieDBs" 用于数据模型。觉得有点陌生是不是,不过这是确保控制器与数据库表进行链接的命名惯例。
添加数据库记录
您可以使用 Visual Web Developer 向 movie 数据库添加一些测试记录。
在 App_Data 文件夹中双击 文件。
右键点击 Database Explorer window 中的 MovieDBs 表,并选择 Show Table Data。
添加记录:
ID
1
2
Title
Psycho
La Dolce Vita
Director
Alfred Hitchcock
Federico Fellini
Date
01.01.1960
01.01.1960
注释:ID 列会自动更新。您不必编辑。
添加链接字符串
向 文件中的
connectionString="Data Source=|DataDirectory|" providerName="verCe.4.0"/> 为了学习 MVC,我们将构建一个 Internet 应用程序。 部分 7:添加数据模型。 MVC 模型 MVC 模型包含所有应用程序逻辑(业务逻辑、验证逻辑、数据访问逻辑),除了纯视图和控制器逻辑。 通过 MVC,模型可保存并操作应用程序数据。 Models 文件夹 Models 文件夹包含表示应用程序模型的类。 Visual Web Developer 自动创建一个 文件,包含用于应用程序安全的模型。 AccountModels 包含 LogOnModel、ChangePasswordModel 以及 RegisterModel。 添加数据库模型 本教程所需的数据库模型能够通过以下几个简单的步骤来创建: 在解决方案管理器中,右键点击 Models 文件夹,选择添加、类。 对类 进行命名,然后点击添加。 编辑这个类: using System; using c; using ; using ; using ; namespace { public class MovieDB { public int ID { get; set; } public string Title { get; set; } public string Director { get; set; } public DateTime Date { get; set; } } public class MovieDBContext : DbContext { public DbSet } } 注释:我们已经把这个表命名为 "MovieDBs" (以 s 结尾)。在前一章,我们看到了用于数据库表的名称 "MovieDBs" (以 s 结尾) 用于数据模型。觉得有点陌生是不是,不过这是确保控制器与数据库表进行链接的命名惯例。 添加数据库控制器 本教程所需的数据库控制器能够通过以下几个简单的步骤来创建: 1. 重建您的项目:选择测试,然后从菜单中选择 Build MvcDemo。 2. 在解决方案资源管理器中,右键点击 Controllers 文件夹,然后选择添加、控制器。 3. 把控制器名称设置为 MoviesController 4. 选择模板:Controller with read/write actions and views, using Entity Framework 5. 选择模型类:MovieDB () 6. 选择 data context 类:MovieDBContext () 7. 选择视图 Razor (CSHTML) 8. 点击添加 Visual Web Developer 将创建如下文件: Controllers 文件夹中的 文件 Views 文件夹中的 Movies 文件夹 添加数据库视图 以下文件会被自动地在 Movies 文件夹中创建: 祝贺你 祝贺您。您已经向应用程序添加了第一个 MVC 数据类型。 现在,您能够在“电影”标签页上点击了。 为了学习 MVC,我们将构建一个 Internet 应用程序。 部分 8:添加安全。 MVC 应用程序安全性 Models 文件夹包含表示应用程序模型的类。 Visual Web Developer 自动创建 文件,该文件包含用于应用程序认证的模型。 AccountModels 包含 LogOnModel、ChangePasswordModel 以及 RegisterModel: Change Password 模型 public class ChangePasswordModel { [Required] [DataType(rd)] [Display(Name = "Current password")] public string OldPassword { get; set; } [Required] [StringLength(100, ErrorMessage = "The {0} must be at least {2} characters long.", MinimumLength = 6)] [DataType(rd)] [Display(Name = "New password")] public string NewPassword { get; set; } [DataType(rd)] [Display(Name = "Confirm new password")] [Compare("NewPassword", ErrorMessage = "The new password and confirmation password do not match.")] public string ConfirmPassword { get; set; } } Logon 模型 public class LogOnModel { [Required] [Display(Name = "User name")] public string UserName { get; set; } [Required] [DataType(rd)] [Display(Name = "Password")] public string Password { get; set; } [Display(Name = "Remember me?")] public bool RememberMe { get; set; } } Register 模型 public class RegisterModel { [Required] [Display(Name = "User name")] public string UserName { get; set; } [Required] [DataType(ddress)] [Display(Name = "Email address")] public string Email { get; set; } [Required] [StringLength(100, ErrorMessage = "The {0} must be at least {2} characters long.", MinimumLength = 6)] [DataType(rd)] [Display(Name = "Password")] public string Password { get; set; } [DataType(rd)] [Display(Name = "Confirm password")] [Compare("Password", ErrorMessage = "The password and confirmation password do not match.")] public string ConfirmPassword { get; set; } } HTML 帮助器用于修改 HTML 输出。 HTML 帮助器 通过 MVC,HTML 帮助器类似于传统的 Web Form 控件。 类似 中的 web form 控件,HTML 帮助器用于修改 HTML。但是 HTML 帮助器更轻。与 web form 控件不同,HTML 帮助器没有事件模型和 view state。 在大多数情况下,HTML 帮助器仅仅是返回字符串的方法。 通过 MVC,您能够创建自己的帮助器,或者使用内建的 HTML 帮助器。 标准的 HTML 帮助器 MVC 包含了大多数常用的 HTML 元素类型的标准帮助器,比如 HTML 链接和 HTML 表单元素。 HTML 链接 呈现 HTML 链接的最简单方法是使用 Link() 帮助器。 通过 MVC,Link() 不连接到视图。它创建控制器操作(controller action)的连接。 Razor 语法: @Link("About this Website", "About") ASP 语法: <%=Link("About this Website", "About")%> 第一个参数是链接文本,第二个参数是控制器操作的名称。 上面的 Link() 帮助器,输出以下 HTML: Link() 帮助器的若干参数: 参数 linkText 描述 定位点元素的内部文本。 actionName controllerName protocol hostname fragment routeValues htmlAttributes 操作的名称。 控制器的名称。 URL 协议,如“http”或“https”。 URL 的主机名。 URL 片段名称(定位点名称)。 一个包含路由参数的对象。 一个对象,包含要为该元素设置的 HTML 特性。 注释:您可以向控制器操作传递值。例如,您能够像数据库编辑操作传递数据库记录的 id。 Razor 语法 C#: @Link("Edit Record", "Edit", new {Id=3}) Razor 语法 VB: @Link("Edit Record", "Edit", New With{.Id=3}) 上面的 Link() 帮助器,输出以下 HTML: HTML 表单元素 以下 HTML 帮助器可用于呈现(修改和输出)HTML 表单元素: BeginForm() EndForm() TextArea() TextBox() CheckBox() RadioButton() ListBox() DropDownList() Hidden() Password() 语法 C#: <%= tionSummary("Create was unsuccessful. Please correct the errors and try again.") %> <% using (orm()){%> <%= x("FirstName") %> <%= tionMessage("FirstName", "*") %>
<%= x("LastName") %>
<%= tionMessage("LastName", "*") %>
<%= rd("Password") %>
<%= tionMessage("Password", "*") %>
<%= rd("ConfirmPassword") %>
<%= tionMessage("ConfirmPassword", "*") %>
<%= ea("Profile", new {cols=60, rows=10})%>
<%= ox("ReceiveNewsletter") %>
<%}%>
学习如何在不使用 Visual Web Developer 的情况下发布 MVC 应用程序。
在不使用 Visual Web Developer 的情况下发布您的应用程序
通过在 WebMatrix、Visual Web Developer 或 Visual Studio 中使用发布命令,可以将
MVC 应用程序发布到远程服务器。
该功能会复制所有应用程序文件、控制器、模型、图像以及所有必需的 DLL 文件,这些文件可能用于 MVC、Web Pages、Razor、Helpers、SQL Server Compact(如果使用了数据库)。
有时您不希望使用这个选项。也许您的主机提供商只支持 FTP?也许您的网站基于经典 ASP?也许您希望自己来复制文件?也许您使用的是其他发布软件?
您会遇到问题吗?是的,会的。但是我们能解决它。
要执行网站复制,您必须了解如何引用正确的文件,复制哪些 DLL 文件,把它们存放到何处。
请按照这些步骤:
1. 使用最新版本的
在继续之前,请确保您的主机运行最新版本的 (4.0)。
2. 复制 Web 文件夹
从开发机上把您的网站(所有文件夹和内容)复制到远程主机(服务器)上的应用程序文件夹。
如果 App_Data 文件夹中包含测试数据,请不要复制这个 App_Data 文件夹。
3. 复制 DLL 文件
在远程服务器上的应用程序根目录中创建 bin 文件夹。(如果您已安装帮助器,则 bin 文件夹已经存在)
从您的文件夹中复制以下所有文件:
C:Program Files (x86)Microsoft Web Pagesv1.0Assemblies
C:Program Files (x86)Microsoft MVC 3Assemblies
到远程服务器上的 bin 文件夹。
4. 复制 SQL Server Compact DLL 文件
如果您的应用程序使用了 SQL Server Compact 数据库(App_Data 文件夹中的 .sdf 文件),那么您必须复制 SQL Server Compact DLL 文件:
从您的文件夹复制以下所有文件:
C:Program Files (x86)Microsoft SQL Server Compact Editionv4.0Private
到远程服务器上的 bin 文件夹。
创建或编辑应用程序中的 文件:
实例 C#
<>
name="Microsoft SQL Server Compact 4.0" description=".NET Framework Data Provider for Microsoft SQL Server Compact" type="roviderFactory, verCe, Version=4.0.0.1,Culture=neutral, PublicKeyToken=89845dcd8080cc91" /> > 5. 复制 SQL Server Compact 数据 您的 App_Data 文件夹中有没有包含测试数据的 .sdf 文件? 您是否希望将测试数据发布到远程服务器? 大多数时候是不希望。 如果您不得不复制 SQL 数据文件(sdf 文件),那么您应该删除数据库中的所有数据,然后把这个空的 .sdf 文件从开发机复制到服务器。 就是这样。祝您好运!
版权声明:本文标题:vs2012 的MVC4实例 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.freenas.com.cn/jishu/1705050162h471227.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论