ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目

                                第一个MVC应用程序

1创建MVC项目

打开VS ,File--新建--项目,选择ASP Web项目,命名后确认。选择(Empty)空模板,

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第1张图片

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第2张图片

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第3张图片

项目创建完成,会看到 解决方案管理器 窗口显示一些文件夹,如图,这是一个MVC的默认结构

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第4张图片

2  添加第一个控制器

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第5张图片

右键 解决方案中的“Controllers”文件夹,从弹出菜单选择 “添加”->“控制器”如上图所示;

添加后出现下图,单击“Add(添加)”按钮

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第6张图片

这是打开 控制器对话框,命名为“Home Controller”,点击添加。

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第7张图片

VS会在Controllers文件夹下创建一个新的C#文件,名称为"Home Controller.cs",这个类如下图所示;

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第8张图片

3 渲染Web界面

创建web界面,在Index界面任意地方右键,从弹出菜单选择“Add View(添加视图)”,如下图:

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第9张图片

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第10张图片

Index.cshtml 基本内容如下所示:

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第11张图片

我们看到:

@{
    Layout = null;
}

这是一个将由Razor视图引擎进行解释的表达式,Razor引擎处理视图内容并生成发送给浏览器的HTML。这是一个简单的Razor表达式,他告诉Razor未选用布局,现在我们暂时忽略,以后在详细介绍。对该页面添加内容。

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第12张图片

调试后出现界面如下

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第13张图片

4 添加动态输出

Web应用程序平台的关键时构造并显示动态输出。在MVC中。控制器的工作时构造一些数据并传递给视图,而视图则负责把他渲染成HTML。

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第14张图片

将数据从控制器传递给视图的一种方式是使用 ViewBag (视图包)对象,他是Controller基类的一个成员。ViewBag 是一种动态对象,看可以给他赋任意属性,这些属性在随后渲染的视图中可用。下面演示了在HomeController.cs 文件中传递一些简单的动态数据。

public ViewResult Index()
        {

            int Hour = DateTime.Now.Hour;
            ViewBag.Greeting = Hour < 12 ? "Good Morning" : "Good afternoon";
            return View();
        }

当ViewBag.Greeting 属性进行赋值时,便是为视图提供数据,Greeting属性直到对其赋值的那一刻才会形成。为了获取到传递的数值,在Index.cshtml 文件做相应修改。

@{
    Layout = null;
}





    
    Index


    
@ViewBag.Greeting World(From the view)

注意:Greeting 可以是任意名称,你也可以写成 @ViewBag.name 只要和Index界面对应就可以实现值传递。

效果如下:

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第15张图片

5 创建一个简单的数据录入程序

场景设置:假设朋友准备举办一场聚会,设计一个Web应用程序,对受邀人进行电子回复(RSVP);

  • 一个显示晚会信息首页
  • 一个用来回复的(PVSP)的表单
  • 对RVSP表单验证,显示一个感谢画面

界面 Views/Home/Index.cshtml 文件添加内容:

@{
    Layout = null;
}





    
    Index
    
    
    


    
@ViewBag.Greeting World(From the view)

我们将会有一个愉悦的party

您是否参加?

@Html.ActionLink("PVSP Now", "RvspForm")

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第16张图片

设计一个数据模型:

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第17张图片

添加模型类:

MVC 约定是将建立模型的类放在“Models”文件夹下,该文件夹是建立项目是自动创建的,右键“解决方案”窗口文件夹“Models”,从弹出窗选择“添加”--“类”,文件名设置为“GuestResponse.cs”,单击添加按钮,创建这个类编辑如下:

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第18张图片

链接动作方法

在Index.cshtml 添加一个指向RSVP表单的链接;

@{
    Layout = null;
}





    
    Index
    
    
    


    
@ViewBag.Greeting World(From the view)

我们将会有一个愉悦的party

您是否参加?

@Html.ActionLink("PVSP Now", "RvspForm")

Html.ActionLink 是HTMLde 辅助器方法 MVC框架附带一组内置的辅助器方法。可以方便地用来渲染HTML的链接,文本输入,复选框以及其他内容。ActionLink一共两个参数,一个是显示文本,第二个是用户单击该连接产生的动作。此时单击该链接会报404错误,因为还没有 /Home/RsvpForm 该界面。此时,在HomeController类中添加一个“RsvpForm”的方法完成。

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第19张图片

添加强类型视图

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第20张图片



ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第21张图片


建立表单

编辑这个RvspForm.cshtml 。

@model MVCStudy.Models.GuestResponse

@{
    Layout = null;
}





    
    RvspForm
    
    
    
    
    


    
@using (Html.BeginForm()) { @Html.ValidationSummary()
@Html.TextBoxFor(x => x.Name, new { @class = "formcontrol" })
@Html.TextBoxFor(x => x.Email, new { @class = "formcontrol" })
@Html.TextBoxFor(x => x.Phone, new { @class = "formcontrol" })
@Html.DropDownListFor(x => x.WillAttend, new[]{ new SelectListItem(){ Text="是,接受邀请",Value=bool.FalseString},new SelectListItem(){ Text = "否,不接受邀请", Value = bool.FalseString } },"请选择",new {@class="formcontrol"})
}
ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第22张图片

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第23张图片

设置启动URL

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第24张图片ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第25张图片

注意:保持特定页空白

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第26张图片

处理表单

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第27张图片

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第28张图片

请求,来调用合适的方法。对HomeController类做修改。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using MVCStudy.Models;

namespace MVCStudy.Controllers
{
    public class HomeController : Controller
    {
        // GET: Home     
        public ViewResult Index()
        {

            int Hour = DateTime.Now.Hour;
            ViewBag.Greeting = Hour < 12 ? "Good Morning" : "Good afternoon";
            return View();
        }

        [HttpGet]
        public ViewResult RvspForm()
        {
            return View();
        }
        [HttpPost]
        public ViewResult RvspForm(GuestResponse guestResponse)
        {
            return View("Thanks",guestResponse);
        }

    }
}


using MVCStudy.Models 命名空间,这样可以直接使用GuestResponse模型类型,而不需要使用这个类的限定名。

使用模型绑定


ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第29张图片ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第30张图片

渲染其他视图

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第31张图片

View\Home\Thanks.cshtml。编辑此视图。

@model MVCStudy.Models.GuestResponse

@{
    Layout = null;
}





    
    
    Thanks
    


    @try
    {
        WebMail.SmtpServer = "smtp.example.com";
        WebMail.SmtpPort = 587;
        WebMail.EnableSsl = true;
        WebMail.UserName = "mySmtpUsername";
        WebMail.Password = "mySmtpPassword";
        WebMail.From = "[email protected]";
        WebMail.Send("[email protected]", "RSVP Notifiaction", Model.Name + "is" + ((Model.WillAttend ?? false) ? "" : "not") + "attending");
    }
    catch(Exception)
    {
        @:对不起,未能给您发送回复邮件
    }


    

Thank you,@Model.Name

@if (Model.WillAttend == true) { @:感谢您的到来 } else { @:您未能参加我们的Party,我们深感遗憾,感谢您的回复。 }

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第32张图片

添加验证


注释属性进行定义。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.ComponentModel.DataAnnotations;
namespace MVCStudy.Models
{
    public class GuestResponse
    {
        [Required(ErrorMessage ="请确认您的姓名")]
        public string Name { get; set; }
        [Required(ErrorMessage = "请确认您的邮箱")]
        [RegularExpression(".+\\@.+\\..+",ErrorMessage ="请输入有效邮箱")]
        public string Email { get; set; }
        [Required(ErrorMessage = "请确认您的电话")]
        public string Phone { get; set; }
        [Required(ErrorMessage = "请确认您是否接受邀请")]
        public bool? WillAttend { get; set; }
    }
}

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第33张图片


ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第34张图片


ValidationSummary()(验证摘要)辅助器方法。

@model MVCStudy.Models.GuestResponse

@{
    Layout = null;
}





    
    RvspForm
    
    
    
    
    


    
@using (Html.BeginForm()) { @Html.ValidationSummary()
@Html.TextBoxFor(x => x.Name, new { @class = "formcontrol" })
@Html.TextBoxFor(x => x.Email, new { @class = "formcontrol" })
@Html.TextBoxFor(x => x.Phone, new { @class = "formcontrol" })
@Html.DropDownListFor(x => x.WillAttend, new[]{ new SelectListItem(){ Text="是,接受邀请",Value=bool.FalseString},new SelectListItem(){ Text = "否,不接受邀请", Value = bool.FalseString } },"请选择",new {@class="formcontrol"})
}
ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第35张图片

高亮显示无效字段

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第36张图片ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第37张图片ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第38张图片

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第39张图片

的内容:

.field-validation-error {
    color: #f00;
}
.field-validation-valid{display:none;}
.input-validation-error{border:1px solid #f00;background-color:#fee;}
.validation-summary-errors{font-weight:bold;color:#f00}
.validation-summary-valid{display:none}

在 RvsvpForm.cshtml中添加Link元素。

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第40张图片

直接从解决方案中用鼠标拖拽文件到相应位置就能自动写Link.

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第41张图片

设置内容样式

使用NuGet安装Bootstrap;

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第42张图片

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第43张图片

找到Bootstrap安装即可。

设置Index视图

@{
    Layout = null;
}





    
    Index
    
    
    


    
@ViewBag.Greeting World(From the view)

我们将会有一个愉悦的party

您是否参加?

@Html.ActionLink("PVSP Now", "RvspForm")

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第44张图片

设置RsvpForm视图

@model MVCStudy.Models.GuestResponse

@{
    Layout = null;
}





    
    RvspForm
    
    
    


    
@using (Html.BeginForm()) { @Html.ValidationSummary()
@Html.TextBoxFor(x => x.Name, new { @class = "formcontrol" })
@Html.TextBoxFor(x => x.Email, new { @class = "formcontrol" })
@Html.TextBoxFor(x => x.Phone, new { @class = "formcontrol" })
@Html.DropDownListFor(x => x.WillAttend, new[] { new SelectListItem() { Text = "是,接受邀请", Value = bool.FalseString }, new SelectListItem() { Text = "否,不接受邀请", Value = bool.FalseString } }, "请选择", new { @class = "formcontrol" })
}



ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第45张图片

设置Thanks视图样式

@model MVCStudy.Models.GuestResponse

@{
    Layout = null;
}





    
    
    Thanks
    


    @try
    {
        WebMail.SmtpServer = "smtp.example.com";
        WebMail.SmtpPort = 587;
        WebMail.EnableSsl = true;
        WebMail.UserName = "mySmtpUsername";
        WebMail.Password = "mySmtpPassword";
        WebMail.From = "[email protected]";
        WebMail.Send("[email protected]", "RSVP Notifiaction", Model.Name + "is" + ((Model.WillAttend ?? false) ? "" : "not") + "attending");
    }
    catch(Exception)
    {
        @:对不起,未能给您发送回复邮件
    }


    

Thank you,@Model.Name

@if (Model.WillAttend == true) { @:感谢您的到来 } else { @:您未能参加我们的Party,我们深感遗憾,感谢您的回复。 }

ASP.NET + MVC5 入门完整教程三 (上) ---第一个MVC项目_第46张图片

源码下载:https://download.csdn.net/download/qq_21419015/10433092

你可能感兴趣的:(ASP.NET,+,MVC5,入门完整教程)