• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >ASP.NET > ASP.NET MVC3手把手教你构建Web

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

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-11

通过本文主要向大家介绍了.net mvc3,.net mvc3 下载,mvc3,mvc3下载,mvc3教程等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

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

环境配置

第一步:到官方网站下载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] 
</div>

构建列表页面

第一步:打开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; } 
 } 
</div>

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

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

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

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

第五步:新建Controller,

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

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


添加后,cshtml代码如下:

@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> 
</div>

运行后效果图如下:


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

添加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(); 
  } 
</div>

添加页面:

@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> 
</div>

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




 
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • ASP.NET MVC3手把手教你构建Web
  • ASP.NET MVC3模板页的使用(2)
  • ASP.NET MVC3网站创建与发布(1)
  • ASP.NET MVC3 实现全站重定向的简单方法
  • ASP.NET MVC3关于生成纯静态后如何不再走路由直接访问静态页面
  • ASP.NET MVC3的伪静态实现代码

相关文章

  • 2017-05-11.Net中如何操作IIS的虚拟目录原理分析及实现方案
  • 2017-05-11Server Application Unavailable出现的原因及解决方案小结
  • 2017-05-11ASP.NET缓存 方法分析和实践示例
  • 2017-05-11asp.net中Timer无刷新定时器的实现方法
  • 2017-05-11ASP.Net防止刷新自动触发事件的解决方案
  • 2017-05-11c# NameValueCollection类读取配置信息
  • 2017-05-11.NET微信公众号开发之查询自定义菜单
  • 2017-05-11asp.net 操作cookie的简单实例
  • 2017-05-11.Net创建Excel文件(插入数据、修改格式、生成图表)的方法
  • 2017-05-11ASP.NET组件System.Web.Optimization原理及缓存问题详解

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • 几个ASP.NET技巧
    • Queryable.Union 方法实现json格式的字符串合并的具体实例
    • Repeater怎么实现多行间隔显示分隔符
    • 基于Jexus-5.6.3使用详解
    • asp.net生成验证码(纯数字)
    • GridView的CheckBox列选择及多参数传递三步搞定
    • asp.net Request.ServerVariables[] 读解
    • .NET+JS对用户输入内容进行字数提示功能的实例代码
    • asp.net 合并GridView中某列相同信息的行(单元格)
    • ASP.NET操作各类时间段获取方法汇总

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有