MVC是当前比较流行的WEB程序开发模式之一,ASP.NET MVC是.Net对MVC的一种实现。本文主要以一些简单的小例子,简述ASP.NET MVC的简单应用,仅供学习分享使用,如有不足之处,还请指正。
MVC是当前比较流行的WEB程序开发模式之一,ASP.NET MVC是.Net对MVC的一种实现。MVC(Model View Controller 模型-视图-控制器)具体如下所示:
MVC 分层有助于管理复杂的应用程序,因为您可以在一个时间内专门关注一个方面。例如,您可以在不依赖业务逻辑的情况下专注于视图设计。同时也让应用程序的测试更加容易。MVC 分层同时也简化了分组开发。不同的开发人员可同时开发视图、控制器逻辑和业务逻辑。
ASP.NET MVC是.Net对MVC三层架构的一种实现方式,在.Net体系中,地位如下:
文件-->新建-->项目,打开项目创建对话框,然后选择ASP.NET Web应用程序(.NET Framework),点击【下一步】。如下所示:
点击【下一步】打开项目配置窗口,输入项目名称,和保存位置,然后点击【创建】,如下所示:
点击【创建】后,打开【创建新的Web应用程序窗口】,选择MVC模板,然后点击【创建】,如下所示:
稍等片刻,即可创建成功。通过模板创建的MVC程序,会自动创建对应的文件夹和默认示例文件,如下所示:
通过点击工具栏的【运行】按钮或快捷键【F5】即可启动Visual Studio自带的IIS Express运行项目,如下所示,
然后在浏览器中打开,输入网址 https:localhost:44310,默认框架模板创建的程序如下所示:
ASP.NET MVC的路由配置在RouteConfig.cs中,默认访问url为{controller}/{action}/{id}的方式,如果为空默认controller为Home,默认action为Index,id为可选项。
即:https://localhost:44301/ 和 https://localhost:44301/Home/Index是等价的。默认配置可以修改,以适应实际业务的需要。
在ASP.NET MVC中,流行【约定大于配置】的说法,即在同一个项目中,大家都按照同一种方式去开发,会使项目更易于维护,可读性更高,同时简化大量的配置,以提高工作效率。ASP.NET MVC中的约定,体现如下:
为了演示程序,首先创建模型类Student,在Models文件夹-->右键-->添加-->类,如下所示:
在【添加新项】窗口中,选择类,输入名称,点击【添加】即可,如下所示:
Student模型类,创建成功后,如下所示:
namespace DemoMvc.Models
{
///
/// 学生实体类
///
public class Student
{
///
/// 唯一标识
///
public int id { get; set; }
///
/// 姓名
///
public string Name { get; set; }
///
/// 年龄
///
public int Age { get; set; }
}
}
在controllers文件夹-->点击右键-->添加-->控制器,如下所示:
在打开的控制器创建对话框,选择【MVC5 控制器 - 空】,点击【创建】,如下所示:
弹出【添加控制器】对话框,输入控制器名称,点击【添加】,如下所示:
控制器创建成功后,默认创建Index功能,并会自动在Views文件夹下创建Student文件夹,如下所示:
在Student文件夹-->右键-->添加-->视图,打开【添加视图】窗口,如下所示:
在【添加视图】窗口,输入视图名称,然后点击【添加】如下所示:
视图创建成功后,默认为Razor视图,如下所示:
修改视图,在视图中添加如下代码,和模型Student进行对应,如下所示:
@{
Layout = null;
}
Index
学生基础信息
运行程序,在浏览器中输入网址:【https://localhost:44310/Student/Index】,如下所示:
在ASP.NET MVC中,为了与用户进行交互,数据需要从浏览器传递到后台,经过业务处理后,再返回给浏览器,呈现给用户,具体流程如下所示:
本次主要分析如何将数据从View层传递到Controller层,及如何从Controller层传递到View层。那具体要如何传递数据呢?
1. 通过内置对象Request进行获取,如下所示:
public ActionResult SaveStudent() {
int id =Convert.ToInt32( Request.Params["id"]);
string Name = Request.Params["Name"].ToString();
int Age = Convert.ToInt32(Request.Params["Age"]);
//Console.WriteLine(string.Format("id = {0},Name = {1},Age = {2}",id,Name,Age));
return View("Index");
}
调试状态下,可以查看从前台获取的值,如下所示:
2. 通过模型类Student进行获取,即以模型类作为入参,前端传递的数据,会自动和模型类中的属性进行匹配,如下所示:
public ActionResult SaveStudent2(Student student)
{
int id = student.id;
string Name = student.Name;
int Age = student.Age;
return View("Index");
}
在调试状态下,可以查询模型类中的属性值,如下所示:
1. 通过ViewData将数据从控制层传递到视图层。
在控制层对ViewData进行赋值,如下所示:
ViewData["msg"] = "请先输入学生信息";
在视图层获取信息并展示,如下所示:
@ViewData["msg"].ToString()
运行起来,如下图所示:
2. 通过ViewBag将数据从控制层传递到视图层,如下所示:
在控制层对ViewBag进行赋值,如下所示:
ViewBag.msg = "请先输入学生信息";
在视图层获取信息并展示,如下所示:
@ViewBag.msg
示例效果和ViewData一致。ViewData和ViewBag对比差异,如下所示:
通过查看代码结构发现,ViewData和ViewBag属于ControllerBase的属性。
同时又是WebViewPage的属性,如下所示:
所以个人猜测:在调用View()返回视图的时候,同时将ViewData和ViewBag进行了赋值,所以才可以在控制层和视图层同时进行使用。
以上是ASP.NET MVC快速入门介绍,旨在抛砖引玉,一起学习,共同进步。