在 MVC 控制器中检索选定的 DropDownList 值
本指南解决了从 MVC 控制器内的 DropDownList 访问所选值的常见挑战。
问题:从 MVC 控制器操作中的 DropDownList 中有效捕获用户的选择。
控制器操作(初始方法):
以下代码演示了使用 FormCollection
的初始尝试:
[HttpPost] public ActionResult ShowAllMobileDetails(MobileViewModel MV) { string strDDLValue = Request.Form["ddlVendor"].ToString(); // Using FormCollection return View(MV); }
型号:
public class MobileViewModel { public List<tbInsertMobile> MobileList; public SelectList Vendor { get; set; } }
查看(部分):
<table> <tr> <td>Mobile Manufacturer</td> <td>@Html.DropDownList("ddlVendor", Model.Vendor, "Select Manufacturer")</td> </tr> </table>
解决方案:
方法一:使用Request.Form
或FormCollection
(不太推荐):
虽然功能强大,但由于依赖字符串操作且缺乏类型安全性,直接访问 Request.Form
通常不太受欢迎。 上面的代码已经演示了这个方法。
方法二:模型绑定(推荐):
这种方法利用 MVC 的模型绑定功能来提供更干净、更易于维护的解决方案。
MobileViewModel
以专门保存所选供应商的值:public class MobileViewModel { // ... existing properties ... public string SelectedVendor { get; set; } }
Html.DropDownListFor
将 DropDownList 绑定到新的 SelectedVendor
属性:@Html.DropDownListFor(m => m.SelectedVendor, Model.Vendor, "Select Manufacturer")
MV.SelectedVendor
属性中:[HttpPost] public ActionResult ShowAllMobileDetails(MobileViewModel MV) { string strDDLValue = MV.SelectedVendor; return View(MV); }
方法 3:检索值和文本(高级):
要获取所选值和其对应的文本,您需要一个隐藏字段和一些jQuery。
public class MobileViewModel { // ... existing properties ... public string SelectedVendor { get; set; } public string SelectedVendorText { get; set; } }
$(function () { $("#SelectedVendor").on("change", function () { $("#SelectedVendorText").val($(this).find(":selected").text()); }); });
@Html.DropDownListFor(m => m.SelectedVendor, Model.Vendor, "Select Manufacturer") @Html.HiddenFor(m => m.SelectedVendorText)
现在,MV.SelectedVendor
(值)和MV.SelectedVendorText
(文本)都将在您的控制器中可用。 请记住将 jQuery 库包含在您的视图中。 这是最强大的解决方案。
请记住选择最适合您的需求和编码风格的解决方案。 通常建议使用模型绑定(方法 2 和 3),因为它的清晰度和可维护性。
以上是如何在 MVC 控制器中检索 DropDownList 的选定值?的详细内容。更多信息请关注PHP中文网其他相关文章!