主頁(yè) > 知識(shí)庫(kù) > ASP.NET MVC3手把手教你構(gòu)建Web

ASP.NET MVC3手把手教你構(gòu)建Web

熱門(mén)標(biāo)簽:安陸市地圖標(biāo)注app 辦公用地圖標(biāo)注網(wǎng)點(diǎn)怎么操作 聊城智能電銷(xiāo)機(jī)器人電話 上海市三維地圖標(biāo)注 海東防封電銷(xiāo)卡 南昌自動(dòng)外呼系統(tǒng)線路 西寧電銷(xiāo)外呼系統(tǒng)公司 云南外呼系統(tǒng)代理 寧德防封版電銷(xiāo)卡

開(kāi)發(fā)工具:VS2010+MSSQL2005,需要使用MVC3.0

環(huán)境配置

第一步:到官方網(wǎng)站下載MVC3,提供了簡(jiǎn)體中文。先安裝 AspNetMVC3ToolsUpdateSetup.exe,然后安裝AspNetMVC3ToolsUpdateVS11Setup.exe

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

第二步:新建數(shù)據(jù)庫(kù),創(chuàng)建測(cè)試表。然后往表里insert些測(cè)試數(shù)據(jù)

USE [yanComdb] 
GO 
/****** 對(duì)象: 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] 

構(gòu)建列表頁(yè)面

第一步:打開(kāi)VS,新建選擇MVC3 web應(yīng)用程序,輸入項(xiàng)目名稱以及目錄

第二步:創(chuàng)建NewsEntity類(lèi),本文使用自己手寫(xiě)實(shí)體類(lèi)(沒(méi)有使用LinqtoSql,EF等orm)

[TableAttribute("NewsEntity")]//這行很重要,因?yàn)閙vc框架默認(rèn)去db中找類(lèi)名復(fù)數(shù)的表名 
 public class NewsEntity 
 { 
  [Key]//設(shè)置主鍵 
  public int NId { get; set; } 
 
  [StringLength(100)]//設(shè)置驗(yàn)證信息 
  [Required(ErrorMessage="標(biāo)題不能為空")] 
  [DisplayName("標(biāo)題")] 
  public string Title { get; set; } 
 
  [Required(ErrorMessage = "正文必須填寫(xiě)")] 
  [DisplayName("正文")] 
  public string Information { get; set; } 
 
  public DateTime Time { get; set; } 
 } 

第三步:配置數(shù)據(jù)庫(kù)連接字符,注意此處的name對(duì)應(yīng)下一步中創(chuàng)建的類(lèi)名。

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

第四步:創(chuàng)建ProjectEntity類(lèi),需要繼承DbContext

public class ProjectEntity : DbContext 
 { 
  public DbSetNewsEntity> 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上右鍵,新建視圖。勾選“創(chuàng)建強(qiáng)類(lèi)型視圖”,選擇NewsEntity,支架模塊選擇List


添加后,cshtml代碼如下:

@model IEnumerableTaiQiu.Models.NewsEntity> 
@{ 
 ViewBag.Title = "后臺(tái)新聞管理列表"; 
 Layout = "~/Views/Shared/_MLayout.cshtml"; 
} 
h2> 
 新聞列表/h2> 
p> 
 @Html.ActionLink("添加", "Create") 
/p> 
table> 
 tr> 
  th width="50px"> 
   ID 
  /th> 
  th width="300px"> 
   標(biāo)題 
  /th> 
  th width="150px"> 
   時(shí)間 
  /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> 

運(yùn)行后效果圖如下:


到此,第一個(gè)列表頁(yè)面就完成了(未涉及分頁(yè),后續(xù)會(huì)更新)。關(guān)于添加,修改,刪除也就很容易了。

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

添加頁(yè)面:

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

修改頁(yè)面一樣,Controller稍微有點(diǎn)修改:

[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,本文也只是本人學(xué)習(xí)中的一點(diǎn)點(diǎn)積累,有很多不好的地方,希望大家多提意思。

您可能感興趣的文章:
  • 使用基于Node.js的構(gòu)建工具Grunt來(lái)發(fā)布ASP.NET MVC項(xiàng)目
  • ASP.NET性能優(yōu)化之構(gòu)建自定義文件緩存
  • Asp.net TreeView來(lái)構(gòu)建用戶選擇輸入的方法 推薦
  • ASP.NET2.0+SQL Server2005構(gòu)建多層應(yīng)用
  • ASP.NET MVC+EF框架+EasyUI實(shí)現(xiàn)權(quán)限管系列
  • ASP.NET中的Inherits、CodeFile、CodeBehind的區(qū)別詳解
  • asp.net(c#)ref,out ,params的區(qū)別
  • asp.net TemplateField模板中的Bind方法和Eval方法
  • ASP.NET Ref和Out關(guān)鍵字區(qū)別分析
  • ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后臺(tái)管理系統(tǒng)之前端頁(yè)面框架構(gòu)建源碼分享

標(biāo)簽:汕尾 南寧 青海 贛州 崇左 洛陽(yáng) 衢州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《ASP.NET MVC3手把手教你構(gòu)建Web》,本文關(guān)鍵詞  ASP.NET,MVC3,手把手,教你,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《ASP.NET MVC3手把手教你構(gòu)建Web》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于ASP.NET MVC3手把手教你構(gòu)建Web的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章