ASP.NET MVC3手把手教你構(gòu)建Web
開(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=en&id=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)目名稱(chē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 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上右鍵,新建視圖。勾選“創(chuàng)建強(qiáng)類(lèi)型視圖”,選擇NewsEntity,支架模塊選擇List
添加后,cshtml代碼如下:
@model IEnumerable<TaiQiu.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)建用戶(hù)選擇輸入的方法 推薦
- 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)建源碼分享
相關(guān)文章
將FreeTextBox做成控件添加到工具箱中的具體操作方法
以下是對(duì)將FreeTextBox做成控件添加到工具箱中的具體操作方法進(jìn)行了詳細(xì)的介紹,需要的朋友可以過(guò)來(lái)參考下2013-09-09解決ASP.NET回傳后div滾動(dòng)條位置復(fù)位的問(wèn)題(利用隱藏控件原理)
這篇文章主要介紹了解決ASP.NET回傳后div滾動(dòng)條位置復(fù)位的問(wèn)題,中心思想是用一個(gè)隱藏控件保存當(dāng)前scorll值?;貍骰貋?lái)后根據(jù)scrollTop的值,然后在Page_Load中重新設(shè)置scrollTop2014-01-01Asp.net程序優(yōu)化js、css實(shí)現(xiàn)合并與壓縮的方法
這篇文章主要介紹了Asp.net程序優(yōu)化js、css實(shí)現(xiàn)合并與壓縮的方法,使用第三方組件實(shí)現(xiàn)訪(fǎng)問(wèn)時(shí)將js與css文件壓縮并緩存在客戶(hù)端的效果,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2014-12-12asp.net發(fā)布后web.config中compilation的debug的值true和false區(qū)別點(diǎn)整理
在本篇文章里小編給大家整理的是一篇關(guān)于asp.net發(fā)布后web.config中compilation的debug的值true和false區(qū)別點(diǎn)內(nèi)容,有需要的為朋友們可以參考下。2020-01-01未能加載文件或程序集“XXX”或它的某一個(gè)依賴(lài)項(xiàng)。試圖加載格式不正確的程序。
如果你將應(yīng)用程序生成x86而不是Any CPU時(shí),在64位操作系統(tǒng)中不會(huì)出錯(cuò)錯(cuò)誤,而在32位操作系統(tǒng)中可能會(huì)出現(xiàn)以下錯(cuò)誤2012-11-11導(dǎo)致Asp.Net站點(diǎn)重啟10個(gè)原因小結(jié)分析
Asp.Net站點(diǎn)有時(shí)候會(huì)莫名其妙的重啟,什么原因?qū)е碌膮s不得而知,經(jīng)過(guò)一番折騰后,我總結(jié)了導(dǎo)致Asp.Net站點(diǎn)重啟的10個(gè)原因,需要的朋友可以參考下。2011-08-08asp.net得到本機(jī)數(shù)據(jù)庫(kù)實(shí)例的兩種方法代碼
這篇文章介紹了asp.net得到本機(jī)數(shù)據(jù)庫(kù)實(shí)例的兩種方法代碼,有需要的朋友可以參考一下2013-07-07ASP.NET Core中如何實(shí)現(xiàn)重定向詳解
這篇文章主要給大家介紹了關(guān)于ASP.NET Core中如何實(shí)現(xiàn)重定向的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01