學習Asp.net MVC-牛刀小試(1)

      在上一篇的文章中,咱們大概理解MVC 的模式後,咱們應該是從基礎入手:
c#

    1.咱們先理解一下程序的入口 瀏覽器

    使用了URL重寫. ASP.NET中叫作UrlRouting,對應的程序集是System.Web.Routing, 打開項目的Global.asax.cs文件, 會找到咱們創建的頁面重寫規則ide

 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  spa

     

     在Controllers文件夾下咱們能夠找到UsersController.cs, 這裏使用了一個約定, 就是若是URL中獲取到的Controller名字是Users, 則他的Controller類名就是UsersController. 在URL中的名字後加上」Controller」.orm

實例中Controller都放在Controllers文件夾, 因此咱們能夠按照命名約定很容易就能夠找到HomeController類對象

       3.查找 Action blog

一個Controller能夠包含多個Action, MVC模式中Controller角色的具體實現邏輯都是在Action中的.繼承

由於咱們的Action是Index, 因此天然就要調用Index()方法.這裏將"Webcome to ASP.NET MVC!",get

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 視圖 it

      View方法中能夠帶一個名字, 這個名字就是View的名字.若是把index改爲Edit,那麼訪問/Users/Edit就會跳轉到Edit頁!

           5. 頁面展現

             接下來ViewEngine即頁面引擎會將aspx中的HTML部分以及上面的數據部分和在一塊兒返回給瀏覽器.

關於View對象我注意到此頁面是繼承自System.Web.Mvc.ViewPage而不是直接繼承自System.Web.UI.Page, 而這個ViewData對象就是ViewPage中的一個屬性. 這裏的ViewData必定是頁面級別的,當頁面編譯完畢這個對象就會被註銷(HTTP是無狀態的協議,每次請求其實都是生成一個新的ViewPage對象).

@model IEnumerable<MvcApplication1.Models.Users>

@{
    ViewBag.Title = "Index";
}

<h2>Index</h2>

<p>
    @Html.ActionLink("Create New", "Create")
</p>
<table>
    <tr>
        <th>
            UserID
        </th>
        <th>
            UserName
        </th>
        <th>
            Password
        </th>
        <th>
            RegTime
        </th>
        <th>
            IsTest
        </th>
        <th>
            IsEnable
        </th>
        <th></th>
    </tr>

@foreach (var item in Model) {
    <tr>
        <td>
            @Html.DisplayFor(modelItem => item.UserID)
        </td>
        <td>
            @Html.DisplayFor(modelItem => item.UserName)
        </td>
        <td>
            @Html.DisplayFor(modelItem => item.Password)
        </td>
        <td>
            @Html.DisplayFor(modelItem => item.RegTime)
        </td>
        <td>
            @Html.DisplayFor(modelItem => item.IsTest)
        </td>
        <td>
            @Html.DisplayFor(modelItem => item.IsEnable)
        </td>
        <td>
            @Html.ActionLink("Edit", "Edit", new { id=item.ID }) |
            @Html.ActionLink("Details", "Details", new { id=item.ID }) |
            @Html.ActionLink("Delete", "Delete", new { id=item.ID })
        </td>
    </tr>
}

</table>

效果圖:

wKioL1QfwWTSYe9TAAD1iT2ojWw372.jpg

相關文章
相關標籤/搜索