ASP.NETMVC3从零开始一步步构建Web

 微软更新速度一直都是很快,目前MVC4.0Beta已经发布了,而我还在刚刚起步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

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

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

构建列表页面

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

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

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

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

 
 
 
 
  1. providerName="System.Data.SqlClient" />

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

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

第五步:新建Controller,

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

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

添加后,cshtml代码如下:

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

运行后效果图如下:

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

添加Controller代码:

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

添加页面:

 
 
 
 
  1. @model TaiQiu.Models.NewsEntity
  2. @{
  3.     ViewBag.Title = "添加新闻";
  4.     Layout = "~/Views/Shared/_MLayout.cshtml";
  5. }
  6.     添加新闻
  7.         var editor;
  8.         KindEditor.ready(function (K) {
  9.             editor = K.create('textarea[name="Information"]', {
  10.                 allowFileManager: true
  11.             });
  12.         });
  13. @using (Html.BeginForm())
  14. {
  15.     @Html.ValidationSummary(true)
  16.     
  17.         News
  18.         
  19.             @Html.LabelFor(model => model.Title)
  20.         
  •         
  •             @Html.TextBoxFor(model => model.Title, new { style = "width:500px" })
  •             @Html.ValidationMessageFor(model => model.Title)
  •         
  •         
  •             @Html.LabelFor(model => model.Information)
  •         
  •         
  •             @Html.TextAreaFor(model => model.Information, new { style="width:800px;height:400px"})
  •             @Html.ValidationMessageFor(model => model.Information)
  •         
  •         

  •             
  •         

  •     
  • }
  •     @Html.ActionLink("返回列表", "Index")
  • 修改页面一样,Controller稍微有点修改:

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

    删除Controller代码:

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

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

    原文:http://www.cnblogs.com/zhxhdean/archive/2012/03/12/2392575.html

    新闻标题:ASP.NETMVC3从零开始一步步构建Web
    网站URL:http://www.csdahua.cn/qtweb/news43/349293.html

    网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

    广告

    声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网

    成都快上网为您推荐相关内容

    品牌网站制作知识

    分类信息网