概述:
FormCollection用来在controller中获取页面表单元素的数据。它是表单元素的集合,包括<input type="submit" />元素。
用法举例:
以下是使用Razor语法的一个表单:
@using (Html.BeginForm())
{
@Html.TextBox("AAA")
@Html.CheckBox("BBB")
<input type="submit" name="submit" value="提交">
}
提交到后台ActionResult为:
[HttpPost]
public ActionResult Index(FormCollection form)
{
string a = form["AAA"];
string b = form["BBB"];
string c = form["submit"];
return View();
}
此时可以得到a="",b="false",c="提交"。要注意的是使用form["AAA"]得到的都是string,需要进行类型转换。
FormCollection和Request.Form的区别:
推荐大家使用FormCollection,原因有以下两点:
1.前者便于单元测试:
对于Action进行单元测试时,使用FormCollection作为输入参数,比Request.Form简单,书写如下代码即可模拟一个FormCollection:
var form = new FormCollection();
form.Add("fieldName","fieldValue");
2.前者可支持MVC扩展:
Asp.net MVC在进行模型绑定时,会将用户输入绑定到FormCollection中,默认情况下,FormCollection中的内容与Request.Form一致,但是当我们自定义ModelBinder时,会影响FormCollection的取值,而Request.Form不会影响。这样如果我们在自定义ModelBinder时依旧使用Request.Form,自定义ModelBinder就毫无用处。