服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服务器之家 - 编程语言 - ASP.NET教程 - ASP.NET MVC3手把手教你构建Web

ASP.NET MVC3手把手教你构建Web

2019-12-21 14:15lijiao ASP.NET教程

微软更新速度一直都是很快,目前最新版本是ASP.NET MVC 5.1,而我还在刚刚起步研究MVC3.0。本文是MVC的基础,构建最简单的MVC项目,感兴趣的小伙伴们可以参考一下

开发工具:VS2010+MSSQL2005,需要使用MVC3.0

环境配置

第一步:到官方网站下载MVC3,提供了简体中文。先安装 AspNetMVC3ToolsUpdateSetup.exe,然后安装AspNetMVC3ToolsUpdateVS11Setup.exe

http://www.microsoft.com/download/en/details.aspx?displaylang=en&id=1491

ASP.NET,MVC3,Web

 

第二步:新建数据库,创建测试表。然后往表里insert些测试数据

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
USE [yanComdb]
GO
/****** 对象: Table [dbo].[NewsEntity] 脚本日期: 03/12/2012 22:03:59 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE TABLE [dbo].[NewsEntity](
 [NId] [int] IDENTITY(1,1) NOT NULL,
 [Title] [nvarchar](100) COLLATE Chinese_PRC_CI_AS NOT NULL,
 [Information] [text] COLLATE Chinese_PRC_CI_AS NULL,
 [Time] [datetime] NOT NULL CONSTRAINT [DF_NewsEntity_Time] DEFAULT (getdate()),
 CONSTRAINT [PK_NewsEntity] PRIMARY KEY CLUSTERED
(
 [NId] ASC
)WITH (PAD_INDEX = OFF, IGNORE_DUP_KEY = OFF) ON [PRIMARY]
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]

构建列表页面

第一步:打开VS,新建选择MVC3 web应用程序,输入项目名称以及目录

ASP.NET,MVC3,Web

ASP.NET,MVC3,Web

第二步:创建NewsEntity类,本文使用自己手写实体类(没有使用LinqtoSql,EF等orm)

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
[TableAttribute("NewsEntity")]//这行很重要,因为mvc框架默认去db中找类名复数的表名
 public class NewsEntity
 {
  [Key]//设置主键
  public int NId { get; set; }
 
  [StringLength(100)]//设置验证信息
  [Required(ErrorMessage="标题不能为空")]
  [DisplayName("标题")]
  public string Title { get; set; }
 
  [Required(ErrorMessage = "正文必须填写")]
  [DisplayName("正文")]
  public string Information { get; set; }
 
  public DateTime Time { get; set; }
 }

第三步:配置数据库连接字符,注意此处的name对应下一步中创建的类名。

?
1
2
3
4
<connectionStrings>
<add name="ProjectEntity" connectionString="Data Source=ip;Initial Catalog=yanComdb;Persist Security Info=True;User ID=;Password="
providerName="System.Data.SqlClient" />
</connectionStrings>

第四步:创建ProjectEntity类,需要继承DbContext

?
1
2
3
4
public class ProjectEntity : DbContext
 {
  public DbSet<NewsEntity> NewsEntity { get; set; }
 }

第五步:新建Controller,

?
1
2
3
4
5
6
7
8
9
10
11
12
13
ProjectEntity PE = new ProjectEntity();
  public ActionResult News()
  {
   try
   {
    var list = PE.NewsEntity.ToList();
    return View(list);
   }
   catch (Exception e)
   {
    throw e;
   }
  }

第六步:在News上右键,新建视图。勾选“创建强类型视图”,选择NewsEntity,支架模块选择List


ASP.NET,MVC3,Web

添加后,cshtml代码如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
@model IEnumerable<TaiQiu.Models.NewsEntity>
@{
 ViewBag.Title = "后台新闻管理列表";
 Layout = "~/Views/Shared/_MLayout.cshtml";
}
<h2>
 新闻列表</h2>
<p>
 @Html.ActionLink("添加", "Create")
</p>
<table>
 <tr>
  <th width="50px">
   ID
  </th>
  <th width="300px">
   标题
  </th>
  <th width="150px">
   时间
  </th>
  <th>
  </th>
 </tr>
 @foreach (var item in Model)
 {
  <tr>
   <td>
    @Html.DisplayFor(modelItem => item.NId)
   </td>
   <td>
    @Html.DisplayFor(modelItem => item.Title)
   </td>
   <td>
    @Html.DisplayFor(modelItem => item.Time)
   </td>
   <td>
    @Html.ActionLink("编辑", "EditNews", new { id = item.NId }) |
    @Html.ActionLink("删除", "DeleteNews", new { id=item.NId })
   </td>
  </tr>
 }
</table>

运行后效果图如下:

ASP.NET,MVC3,Web

到此,第一个列表页面就完成了(未涉及分页,后续会更新)。关于添加,修改,删除也就很容易了。

添加Controller代码:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
[HttpPost]
  [ValidateInput(false)]
  public ActionResult Create(NewsEntity news)
  {
   if (ModelState.IsValid)
   {
    news.Time = DateTime.Now;
    PE.NewsEntity.Add(news);
    try
    {
     PE.SaveChanges();
     return RedirectToAction("News");
    }
    catch (Exception e)
    {
     throw e;
    }
 
   }
   return View();
  }

添加页面:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
@model TaiQiu.Models.NewsEntity
@{
 ViewBag.Title = "添加新闻";
 Layout = "~/Views/Shared/_MLayout.cshtml";
}
<h2>
 添加新闻</h2>
<script src="@Url.Content("~/Scripts/jquery.validate.min.js")" type="text/javascript"></script>
<script src="@Url.Content("~/Scripts/jquery.validate.unobtrusive.min.js")" type="text/javascript"></script>
<script src="@Url.Content("~/Scripts/kindeditor/kindeditor.js")" type="text/javascript"></script>
<script src="@Url.Content("~/Scripts/kindeditor/lang/zh_CN.js")" type="text/javascript"></script>
<script type="text/javascript">
  var editor;
  KindEditor.ready(function (K) {
   editor = K.create('textarea[name="Information"]', {
    allowFileManager: true
   });
  });
</script>
@using (Html.BeginForm())
{
 @Html.ValidationSummary(true)
 <fieldset>
  <legend>News</legend>
  <div class="editor-label">
   @Html.LabelFor(model => model.Title)
  </div>
  <div class="editor-field">
   @Html.TextBoxFor(model => model.Title, new { style = "width:500px" })
   @Html.ValidationMessageFor(model => model.Title)
  </div>
  <div class="editor-label">
   @Html.LabelFor(model => model.Information)
  </div>
  <div class="editor-field">
   @Html.TextAreaFor(model => model.Information, new { style="width:800px;height:400px"})
   @Html.ValidationMessageFor(model => model.Information)
  </div>
  <p>
   <input type="submit" value="Create" />
  </p>
 </fieldset>
}
<div>
 @Html.ActionLink("返回列表", "Index")
</div>

修改页面一样,Controller稍微有点修改:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
[HttpPost]
  [ValidateInput(false)]
  public ActionResult EditNews(NewsEntity news)
  {
   if (ModelState.IsValid)
   {
    news.Time = DateTime.Now;
    PE.Entry(news).State = EntityState.Modified;//修改
    PE.SaveChanges();
    return RedirectToAction("News");
   }
   return View(news);
  }

删除Controller代码:

?
1
2
3
4
5
6
7
public ActionResult DeleteNews(int id)
  {
   var model = PE.NewsEntity.Find(id);
   PE.NewsEntity.Remove(model);
   PE.SaveChanges();
   return RedirectToAction("News");
  }

小编刚接触MVC3,本文也只是本人学习中的一点点积累,有很多不好的地方,希望大家多提意思。

延伸 · 阅读

精彩推荐