Yo
У меня на сайте есть страница регистрации — вверху страницы находится форма входа для существующих пользователей. В основной области находится регистрационная форма.
Вход в систему является частичным просмотром с @model ViewModels.LoginViewModel
Регистрация также является частичной с @model ViewModels.RegViewModel
Главная страница, на которой размещены эти фрагменты, представляет собой вид с @model ViewModels.RegPageViewModel
.
Эта модель просмотра выглядит так:
public class RegViewModel
{
public RegisterVm RegisterVm { get; set; }
public LoginVm LoginVm { get; set; }
}
Когда я отправляю регистрационную часть страницы (это действие - регистрация/захват - принимающее действие ожидает RegisterVm) его контроллеру, он жалуется на то, что ему передана неправильная модель представления.
Как обстоят дела с подпредставлениями и их моделью представления? Есть ли стандартный подход к этому?
Должен ли я иметь один URL-адрес отправки для этой страницы, который определяет, является ли это запросом на вход в систему или запросом на регистрацию, а затем соответствующим образом обрабатывает сообщение? Хотя мне это кажется грязным...
http://monobin.com/__d33cf45a4 — RegisterVm.cs (LoginVm.cs почти такой же)
http://monobin.com/__m69132f76 — RegPageVm.cs
Регистр.cshtml:
@model xxxx.ViewModels.RegPageVm
@{
View.Title = "Register";
Layout = "~/Views/Shared/_BareBones.cshtml";
}
<link rel="stylesheet" href="@Url.Content("~/Public/Css/signup.css")" type="text/css" />
<div id="sign-up-container">
<div id="sign-up-box">
<div id="sign-up-box-left">
<img src="@Url.Content("~/Public/Images/Signup_176x81.png")" />
</div>
<div id="sign-up-box-right">
@Html.Partial("_Register")
</div>
</div>
</div>
<div class="clear">
</div>
_Регистр.cshtml:
@model xxxx.ViewModels.RegisterVm
@using (Html.BeginForm("Capture", "Register", FormMethod.Post))
{
<table class="sign-up-box-inner">
<tr>
<td class="label-area">
@Html.LabelFor(x => x.Email)
</td>
<td class="field-area">
@Html.TextBoxFor(x => x.Email, new { @class = "login-input", title = "Enter Name" })
</td>
</tr>
<tr>
<td class="label-area">
@Html.LabelFor(x => x.Password)
</td>
<td class="field-area">
@Html.PasswordFor(x => x.Password, new { @class = "login-input", title = "Enter Name" })
</td>
</tr>
<tr>
<td class="label-area">
@Html.LabelFor(x => x.UserName)
</td>
<td class="field-area">
@Html.TextBoxFor(x => x.UserName, new { @class = "login-input", title = "Enter Name" })
</td>
</tr>
<tr>
<td colspan="2">
<input type="image" src="../../Public/Images/Submit_150x47.png" class="submit-button" />
</td>
</tr>
</table>
@Html.AntiForgeryToken()
}
И, наконец, RegisterController.cs:
public class RegisterController : Controller
{
public ActionResult Index()
{
return View();
}
[HttpPost, ValidateAntiForgeryToken]
public ActionResult Capture(RegisterVm registerVm)
{
if (!ModelState.IsValid)
{
return View("index", new RegPageVm()
{
LoginVm = new LoginVm(),
RegisterVm = registerVm
});
}
return RedirectToAction("index", "Event");
}
}
w://