在上一篇的文章中,我們大概理解MVC 的模式后,我們應(yīng)該是從基礎(chǔ)入手:
創(chuàng)新互聯(lián)公司專注于興海網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗(yàn)。 熱誠為您提供興海營銷型網(wǎng)站建設(shè),興海網(wǎng)站制作、興海網(wǎng)頁設(shè)計、興海網(wǎng)站官網(wǎng)定制、微信平臺小程序開發(fā)服務(wù),打造興海網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供興海網(wǎng)站排名全網(wǎng)營銷落地服務(wù)。
1.我們先理解一下程序的入口
使用了URL重寫. ASP.NET中叫做UrlRouting,對應(yīng)的程序集是System.Web.Routing, 打開項(xiàng)目的Global.asax.cs文件, 會找到我們建立的頁面重寫規(guī)則
public static void RegisterRoutes(RouteCollection routes) { routes.IgnoreRoute("{resource}.axd/{*pathInfo}"); routes.MapRoute( "Default", // Route name "{controller}/{action}/{id}", // URL with parameters new { controller = "Users", action = "Index", id = UrlParameter.Optional } // Parameter defaults ); } protected void Application_Start() { AreaRegistration.RegisterAllAreas(); System.Data.Entity.Database.SetInitializer(new MvcApplication1.Models.UsersInitializer()); RegisterGlobalFilters(GlobalFilters.Filters); RegisterRoutes(RouteTable.Routes); }
2.查找 Controller
在Controllers文件夾下我們可以找到UsersController.cs, 這里使用了一個約定, 就是如果URL中獲取到的Controller名字是Users, 則他的Controller類名就是UsersController. 在URL中的名字后加上”Controller”.
實(shí)例中Controller都放在Controllers文件夾, 所以我們可以按照命名約定很容易就可以找到HomeController類
3.查找 Action
一個Controller可以包含多個Action, MVC模式中Controller角色的具體實(shí)現(xiàn)邏輯都是在Action中的.
因?yàn)槲覀兊腁ction是Index, 所以自然就要調(diào)用Index()方法.這里將"Webcome to ASP.NET MVC!",
private UsersDbContext db = new UsersDbContext(); // // GET: /Users/ public ViewResult Index() { return View(db.Users.ToList()); } // // GET: /Users/Details/5 public ViewResult Details(int id) { Users users = db.Users.Find(id); return View(users); } // // GET: /Users/Create public ActionResult Create() { return View(); } // // POST: /Users/Create [HttpPost] public ActionResult Create(Users users) { if (ModelState.IsValid) { db.Users.Add(users); db.SaveChanges(); return RedirectToAction("Index"); } return View(users); } // // GET: /Users/Edit/5 public ActionResult Edit(int id) { Users users = db.Users.Find(id); return View(users); } // // POST: /Users/Edit/5 [HttpPost] public ActionResult Edit(Users users) { if (ModelState.IsValid) { db.Entry(users).State = EntityState.Modified; db.SaveChanges(); return RedirectToAction("Index"); } return View(users); } // // GET: /Users/Delete/5 public ActionResult Delete(int id) { Users users = db.Users.Find(id); return View(users); } // // POST: /Users/Delete/5 [HttpPost, ActionName("Delete")] public ActionResult DeleteConfirmed(int id) { Users users = db.Users.Find(id); db.Users.Remove(users); db.SaveChanges(); return RedirectToAction("Index"); } protected override void Dispose(bool disposing) { db.Dispose(); base.Dispose(disposing); }
4.查找view 視圖
View方法中可以帶一個名字, 這個名字就是View的名字.如果把index改成Edit,那么訪問/Users/Edit就會跳轉(zhuǎn)到Edit頁!
5. 頁面展示
接下來ViewEngine即頁面引擎會將aspx中的HTML部分以及上面的數(shù)據(jù)部分和在一起返回給瀏覽器.
關(guān)于View對象我注意到此頁面是繼承自System.Web.Mvc.ViewPage而不是直接繼承自System.Web.UI.Page, 而這個ViewData對象就是ViewPage中的一個屬性. 這里的ViewData一定是頁面級別的,當(dāng)頁面編譯完畢這個對象就會被注銷(HTTP是無狀態(tài)的協(xié)議,每次請求其實(shí)都是生成一個新的ViewPage對象).
@model IEnumerable@{ ViewBag.Title = "Index"; } Index
@Html.ActionLink("Create New", "Create")
效果圖:
@foreach (var item in Model) { UserID UserName Password RegTime IsTest IsEnable } @Html.DisplayFor(modelItem => item.UserID) @Html.DisplayFor(modelItem => item.UserName) @Html.DisplayFor(modelItem => item.Password) @Html.DisplayFor(modelItem => item.RegTime) @Html.DisplayFor(modelItem => item.IsTest) @Html.DisplayFor(modelItem => item.IsEnable) @Html.ActionLink("Edit", "Edit", new { id=item.ID }) | @Html.ActionLink("Details", "Details", new { id=item.ID }) | @Html.ActionLink("Delete", "Delete", new { id=item.ID })