控制器方法获取View页面传送的数据有多种方法,以Edit方法为例:
1、Form表单请求收集方式
包括Request.Form或者FormCollection。
如下:
[HttpPost] public ActionResult Edit(FormCollection collection) { var album = new Album(); if (ModelState.IsValid) { // EntityState.Modified表示这条数据是修改的,已有的,而不是新建的 album.Title=collection["Title"]; album.Title = Request.Form["Title"]; db.Entry(album).State = EntityState.Modified; db.SaveChanges(); return RedirectToAction("Index"); } ViewBag.GenreId = new SelectList(db.Genres, "GenreId", "Name", album.GenreId); ViewBag.ArtistId = new SelectList(db.Artists, "ArtistId", "Name", album.ArtistId); return View(album); }
这样直接获取表单请求的数据,代码会变得冗长乏味。上面只是设置了两个属性,如果有10个或者更多个,写起来太累。而且任何不是字符串类型的属性还需要自己进行类型转换。
注意:Request.Form["Title"],必须在页面的有可编辑标签的name值为”Title”,根据html标签的name值获取该标签的数据。
2、 DefaultModelBinder
通过View页面上的类型对象作为参数传递数据
如Edit页面头部引用:@model MusicStore.Models.Album
Edit方法代码如下:
[HttpPost] public ActionResult Edit(Album album) { if (ModelState.IsValid) { // EntityState.Modified表示这条数据是修改的,已有的,而不是新建的 db.Entry(album).State = EntityState.Modified; db.SaveChanges(); return RedirectToAction("Index"); } ViewBag.GenreId = new SelectList(db.Genres, "GenreId", "Name", album.GenreId); ViewBag.ArtistId = new SelectList(db.Artists, "ArtistId", "Name", album.ArtistId); return View(album); }
当操作带有一个参数时,MVC机制就会使用一个模型绑定器来构建这个参数对象。在Album对象的情形中,默认的模型绑定检查Album类,并查找能用于绑定的所有Album属性。因为MVC视图的命名都是非常规范的, 标签的name值和实体类的属性值一样。这样,遵照命名约定,默认的模型绑定器能自动将请求中的值转换和移入到一个Album对象中。如当模型绑定器看到Album有Title属性时,它就在请求中查找名为”Title”的参数,查到就加进来。
3、显示模型绑定
使用UpdataModel和TryUpdataModel方法显式调用模型绑定.如果使用UpdataModel方法,如在模型绑定期间出现错误或者模型无效,则会抛出一个异常。而TryUpdataModel方法则不会抛出异常,它返回的是一个布尔类型的值:true or false,true表示成功。
以TryUpdataModel为例:
[HttpPost] public ActionResult Edit() { var album = new Album(); if (ModelState.IsValid) { TryUpdateModel(album); // EntityState.Modified表示这条数据是修改的,已有的,而不是新建的 db.Entry(album).State = EntityState.Modified; db.SaveChanges(); return RedirectToAction("Index"); } else { ViewBag.GenreId = new SelectList(db.Genres, "GenreId", "Name", album.GenreId); ViewBag.ArtistId = new SelectList(db.Artists, "ArtistId", "Name", album.ArtistId); return View(album); } }