好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

ASP.NET MVC3 从零开始一步步构建Web

ASP.NET MVC3 从零开始一步步构建Web

微软更新速度一直都是很快,目前MVC4.0Beta已经发布了,而我还在刚刚起步MVC3.0。本文是MVC的基础,构建最简单的MVC项目。以后会陆续发布更新。

环境配置

第一步:到官方网站下载MVC3,提供了简体中文。先安装 AspNetMVC3ToolsUpdateSetup.exe,然后安装AspNetMVC3ToolsUpdateVS11Setup.exe  http://www.microsoft.com/download/en/details.aspx?displaylang=en&id=1491

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

 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应用程序,输入项目名称以及目录

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

    
[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对应下一步中创建的类名。

 <  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

     public   class  ProjectEntity : DbContext
{
public DbSet<NewsEntity> NewsEntity { get ; set ; }
}

复制代码

第五步:新建Controller,

        ProjectEntity PE =  new  ProjectEntity();
public ActionResult News()
{
try
{
var list = PE.NewsEntity.ToList();
return View(list);
}
catch (Exception e)
{
throw e;
}
}

复制代码

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

添加后,cshtml代码如下:

View Code

运行后效果图如下:

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

添加Controller代码:

       [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();
}

复制代码

添加页面:

View Code

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

     [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代码:

       public  ActionResult DeleteNews( int  id)
{
var model = PE.NewsEntity.Find(id);
PE.NewsEntity.Remove(model);
PE.SaveChanges();
return RedirectToAction( " News " );
}

复制代码

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

小弟刚接触MVC3.0,虽然已有几年web开发,也使用过fckeditor,xheditor,freetext,kindeditor等html在线编辑器。

但是在MVC环境下还没有使用过。今天自己折腾了好一会才解决。项目中使用的是kindeditor.

文件有600多k,但是实际使用只需要其中几个文件。解压文件后,copy 根目录2个js文件,以及themes(放的样式、图片)文件夹,plugins文件夹,lang文件夹中是语言,我们只需要其中的zh_CN.js。最后放项目中的文件如下截图:

第二步:引入js文件,初始化编辑器。对于细化编辑器的可以参考官网demo http://www.kindsoft.net/demo.php

?

<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>

第三步:使用KindEditor

?

@Html.TextAreaFor(model => model.Information, new { })

第四步:Controller,要设置ValidateInput false,不然有html标签会报错的。

?

[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();

  }

最后在页面上效果图:

 

mvc

【原创】ASP.NET MVC3 从零开始一步步构建Web

posted @  2012-03-12 22:37  zhxhdean 阅读(1351) |  评论 (7)   编辑

【原创】ASP.NET MVC3使用html编辑器(kindeditor)

posted @  2012-03-10 21:10  zhxhdean 阅读(872) |  评论 (6)   编辑

【转载】ASP.NET MVC HtmlHelper类的辅助和扩展方法

posted @  2012-03-09 09:53  zhxhdean 阅读(152) |  评论 (0)   编辑

作者: Leo_wl

    

出处: http://www.cnblogs.com/Leo_wl/

    

本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

版权信息

查看更多关于ASP.NET MVC3 从零开始一步步构建Web的详细内容...

  阅读:51次