ASP.NET MVC 2 学习笔记二: 表单的灵活提交
前面说到有做到公司内部的一个请假系统,用的是ASP.NET MVC 2+Entity Framework。虽然EF(Entity Framework简称,以下简称EF,恕不赘述)简单方便,提供了几乎大半的数据库访问的方法。但是,仍然有些瑕疵,所以不得不综合linq方法,以期达到完美。
表单提交问题,EF提供了TryUpdateModel和UpdateModel两种方法来更新数据表,例如,我要更新请假的信息时,可以这样写:
1 [HttpPost]
2 public ActionResult EditLeaving(FormCollection form)
3 {
4 var infoid = Int32.Parse(form["infoid"]);
5 var leavingInfoToUpdate = _Staffdb.LeavingInformation.First(m => m.InfoId == infoid);
6
7 // Deserialize (Include white list!)
8 TryUpdateModel(leavingInfoToUpdate, new string[] { "StartTime", "EndTime", "Details" }, form.ToValueProvider());
9
10
11 if (String.IsNullOrEmpty(leavingInfoToUpdate.StartTime.ToString()))
12 ModelState.AddModelError("StartTime", "StartTime is required!");
13 if (String.IsNullOrEmpty(leavingInfoToUpdate.EndTime.ToString()))
14 ModelState.AddModelError("EndTime", "EndTime is required!");
15
16
17 if (ModelState.IsValid && leavingInfoToUpdate.Details.ToString() != "")
18 {
19 _Staffdb.SaveChanges();
20 return RedirectToAction("RequestLeave");
21 }
22
23 // Otherwise, reshow form
24 return View(leavingInfoToUpdate);
25 }
可以看出TryUpdateModel方法第一个参数是要更新的数据行leavingInfoToUpdate,第二个参数列了一份白名单,其中包括了要更新的字段名StartTime、EndTime和Details,第三个参数传进数据的提供源信息,这里使用表单提交form.ToValueProvider()。
如果采用这种更新方式,很明显不够灵活,当然TryUpdateModel还有第四个参数,列出一份黑名单,即使不更新的字段。但是如果所列出的某些字段,不是由表单提供的,例如RequestTime字段,是由表单提交时的当前时间提供,怎们办呢?
在网上找了很久,终于找到一种方法,应该来说是在ASP.NET MVC 1.0中提供,就能够比较灵活的解决当前表单提交的问题。下面,我就在管理员身份时,对添加员工的表单提交,举例如下,下面是Controllers层的代码:
1 /// <summary>
2 /// 添加员工信息
3 /// </summary>
4 /// <returns></returns>
5 public ActionResult AddStaff()
6 {
7 var alicename = Environment.UserName;
8 var personInfo = _Staffdb.StaffList.First(m => m.AliceName == alicename);
9
10 var id = personInfo.Id;
11 ViewData["StaffId"] = id;
12
13 List<StaffIdentity> identity = _Staffdb.StaffIdentity.ToList();
14 ViewData["Identity"] = new SelectList(identity,"IdentityId","IdentityName");
15
16 return View();
17 }
18
19 [HttpPost]
20 public ActionResult AddStaff(FormCollection form)
21 {
22 StaffList stafflist = new StaffList();
23 stafflist.AliceName = form["AliceName"];
24 stafflist.EnName = form["EnName"];
25 stafflist.CnName=form["CnName"];
26
27 int identityid = Convert.ToInt32(form["IdentityName"].ToString());
28 stafflist.IdentityId = identityid;
29
30 _Staffdb.AddToStaffList(stafflist);
31 _Staffdb.SaveChanges();
32
33 return RedirectToAction("ShowStaffInfo");
34 }
上面的alicename是由Environment.UserName来获取的当前系统用户的用户名。在表单提交的Action方法AddStaff中,首先new一个StaffList表的同名实体模型类stafflist,然后依次通过stafflist.AliceName = form["AliceName"]; 的方法来给这个模型类对象赋予表单中提供的值。重点是,请注意,stafflist.IdentityId = identityid; 得identityid是通过我所需要的值转换而来的。然后再把这个对象加在_staffdb之中,保存即可。这样,就可以很灵活的更新我所需要的值,而不单单是表单提供值的方法来提供了。
其中,AddStaff界面如下:
OK,至此,表单的灵活提交问题已经解决了!
Ps:本人的界面美工不是很好,所以就简单采用了微软提供的例子程序中的css。见谅见谅,呵呵!