我为我传递到视图中的字符串List中的每个项动态生成DropDownList,然后为一些标准选项生成下拉列表,下拉列表名称为字母“drp”+通过视图传递的String项可视数据。我遇到的问题是我无法弄清楚如何在视图中访问HttpPost中的单个下拉列表,因为项目的名称和数量各不相同。
以下是我的观点获取代码:
public ActionResult ModMapping()
{
ViewData["mods"] = TempData["mods"];
return View();
}
这是我的观看生成:
<% using (Html.BeginForm()) { %>
<h2>Modifier Needing Mapping</h2>
<p>Please Choose for each modifier listed below what type of fee it is. There is an ingore option if it is not a gloabl fee modifier, professional fee modifier, or technical fee modifier.</p>
<table>
<tr>
<th>Modifier</th>
<th>Mapping Options</th>
</tr>
<% int i;
i=0;
var modsList = ViewData["mods"] as List<String>;%>
<% foreach (String item in modsList) { %>
<% i++; %>
<tr>
<td>
<%: Html.Label("lbl" + item, item) %>
</td>
<td>
<%: Html.DropDownList("drp" + item, new SelectList(
new List<Object>{
new { value = "NotSelected" , text = "<-- Select Modifier Type -->"},
new { value = "Global" , text = "Global Fee" },
new { value = "Professional" , text = "Professional Fee"},
new { value = "Technical", text = "Technical Fee"},
new { value = "Ingore", text="Ingore This Modifier"}
},
"value",
"text",
"NotSelected")) %>
</td>
</tr>
<% } %>
</table>
<input type="submit" value="Done" />
<% } %></code>
答案 0 :(得分:0)
如果您为视图使用模型,这非常简单,因为MVC会自动将所有下拉列表映射回您的模型。
如果您确实不想使用模型you can access the values in the form like this:
// Load your modsList here.
foreach (String item in modsList)
{
var dropDownValue = Request["drp" + item];
}
另一种选择是编写一个接受FormCollection的控制器函数,它只是POST中所有值的简单字典:
[HttpPost]
public ActionResult ModMapping(FormCollection formCollection)
{
// Load your modsList here.
foreach (String item in modsList)
{
var dropDownValue = formCollection["drp" + item];
}
}
你可以简化一些事情,只需循环遍历FormCollection,查找以“drp”开头的项目,具体取决于你的页面和要求是什么样的。