Asp.net mvc UpdateModel前缀-ASP.NET MVC
我在使用Asp.net mvc UpdateModel前缀-ASP.NET MVC,asp.net-mvc,Asp.net Mvc,我在使用TryUpdateModel()时遇到问题。我的表单字段以前缀命名,但我使用-作为分隔符,而不是默认点 <input type="text" id="Record-Title" name="Record-Title" /> 可以使用自定义分隔符吗?除非您实现自己的ModelBinder。如果查看上DefaultModelBinder的源代码,您将看到,当您指定前缀时,它通过连接前缀、句点和属性名称来构造名称。不幸的是,DefaultModelBinder上执行此操作的方法是
TryUpdateModel()
时遇到问题。我的表单字段以前缀命名,但我使用-作为分隔符,而不是默认点
<input type="text" id="Record-Title" name="Record-Title" />
可以使用自定义分隔符吗?除非您实现自己的ModelBinder。如果查看上DefaultModelBinder的源代码,您将看到,当您指定前缀时,它通过连接前缀、句点和属性名称来构造名称。不幸的是,DefaultModelBinder上执行此操作的方法是私有静态的,因此无法在派生类中重写。另外需要注意的是,前缀用于帮助反射找到要更新的正确字段。例如,如果我的ViewData有一个自定义类,例如:
public class Customer
{
public string FirstName {get; set;}
public string LastName {get; set;}
}
public class MyCustomViewData
{
public Customer Customer {get; set;}
public Address Address {get; set;}
public string Comment {get; set;}
}
我的页面上有一个文本框
<%= Html.TextBox("FirstName", ViewData.Model.Customer.FirstName) %>
有一个不使用的理由。作为HTML bcs中的ID/Name,它不是标准的。例如,如果目标中有一个点,则将中断。这是一个错误的决定,使用句点。这样会更好 这意味着您必须单独定义所有ID
ie.Textbox现在有Html.Textbox(“test.test”,new{@id=“test”)您可以简单地使用第二个示例:下划线用于Html/CSS id。点仅用于表单输入名称。
<%= Html.TextBox("FirstName", ViewData.Model.Customer.FirstName) %>
<%= Html.TextBox("Customer.FirstName", ViewData.Model.Customer.FirstName) %>
public ActionResult Save (Formcollection form)
{
MyCustomViewData model = GetModel(); // get our model data
TryUpdateModel(model, form); // works for name="Customer.FirstName" only
TryUpdateModel(model.Customer, form) // works for name="FirstName" only
TryUpdateModel(model.Customer, "Customer", form); // works for name="Customer.FirstName" only
TryUpdateModel(model, "Customer", form) // do not work
..snip..
}