zoukankan      html  css  js  c++  java
  • ASP.NET MVC 2 学习笔记二: 表单的灵活提交

    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。见谅见谅,呵呵!

  • 相关阅读:
    mysql GRANT ALL PRIVILEGES 限制某个或所有客户端都可以连接至mysql
    MySql开启远程用户登录GRANTALLPRIVILEGESON*.*TO'root'@'%'I MySql开启远程用户登录GRANTALLPRIVILEGESON*.*TO'root'@'%'I
    php中 -> 和 => 和 :: 的用法 以及 self 和 $this 的用法
    mysql case when then else end 的用法
    C/C++ 程序的build过程
    Git 笔记
    English Snippets
    Ubuntu 使用笔记
    在CentOS上安装Sublime Text
    hihoCoder #1379 Emulator
  • 原文地址:https://www.cnblogs.com/MarkRao/p/2355475.html
Copyright © 2011-2022 走看看