在一个包含多个表单和状态的页面中,可以使用不同的属性和视图模型来处理每个表单的数据。通过将每个表单的数据绑定到一个不同的模型中,可以轻松地将这些数据传递到控制器。
以下是一个示例,在其中有两个表单分别用于添加和编辑用户信息:
模型:
public class AddUserViewModel { public string FirstName { get; set; } public string LastName { get; set; } public string Email { get; set; } public string Password { get; set; } }
public class EditUserViewModel { public int UserId { get; set; } public string FirstName { get; set; } public string LastName { get; set; } public string Email { get; set; } }
视图:
@model AddUserViewModel
@using (Html.BeginForm("AddUser", "User")) { @Html.TextBoxFor(m => m.FirstName) @Html.TextBoxFor(m => m.LastName) @Html.TextBoxFor(m => m.Email) @Html.TextBoxFor(m => m.Password)
}
@model EditUserViewModel
@using (Html.BeginForm("EditUser", "User")) { @Html.HiddenFor(m => m.UserId) @Html.TextBoxFor(m => m.FirstName) @Html.TextBoxFor(m => m.LastName) @Html.TextBoxFor(m => m.Email)
}
控制器:
public class UserController : Controller { public IActionResult AddUser() { return View(new AddUserViewModel()); }
[HttpPost]
public IActionResult AddUser(AddUserViewModel model)
{
// 处理添加用户的数据
return RedirectToAction("Index");
}
public IActionResult EditUser(int id)
{
// 获取用户数据
var user = GetUserById(id);
// 将数据绑定到模型中
var model = new EditUserViewModel
{
UserId = user.UserId,
FirstName = user.FirstName,
LastName = user.LastName,
Email = user.Email
};
return View(model);
}
[HttpPost]
public IActionResult EditUser(EditUserViewModel model)
{
// 处理编辑用户的数据
return RedirectToAction("Index");
}
}
在这个示例中,每个表单都有一个对应的模型,并且每个模