Проверка на стороне клиента MVC3 - чего мне не хватает?
Я погуглил, посмотрел блоги, проверил несколько ответов здесь на SO... когда я включаю "Проверка на стороне клиента" в моем приложении MVC3, проверка происходит только на сервере, а не на клиенте - моя форма отправляет с требуемым текстовые вводы, которые не имеют значений, только для возврата на сервер.
Полное раскрытие: я никогда не заставлял это работать последовательно и полностью ни в одном из 3 проектов MVC, которые я делал до сих пор. Я убежден, что упускаю что-то фундаментальное здесь, так как подавляющее большинство примеров и практических рекомендаций я считаю несущими "Эта статья относится к бета-версии", отказ от ответственности...
Это обычно тот момент, когда я расстраиваюсь и вырываю все "все на стороне клиента должно быть косвенным и волшебным, потому что мы боимся, что разработчики пишут мусор javascript" и просто используют jquery.validation напрямую, но я решил, что попробую размещать здесь, чтобы увидеть, если я упускаю что-то фундаментальное... как я обычно, кажется;)
Эта модель:
public class RegisterModel
{
[Required]
public string FirstName { get; set; }
[Required]
public string LastName { get; set; }
[Required]
public string Email { get; set; }
[Required]
public string Password { get; set; }
[Required]
public string ConfirmPassword { get; set; }
}
Это представление (классы "текстовое поле" необходимы для стиля):
@using (Html.BeginForm()) {
@Html.ValidationSummary(true)
<div class="form-item-right">
@Html.ValidationMessageFor(model => model.FirstName, "First Name is required.")
@Html.TextBoxFor(model => model.FirstName, new { @class = "textfield" })
@Html.LabelFor(model => model.FirstName, "First Name")
</div>
<div class="form-item-right">
@Html.ValidationMessageFor(model => model.LastName)
@Html.TextBoxFor(model => model.LastName, new { @class = "textfield" })
@Html.LabelFor(model => model.LastName, "Last Name")
</div>
<div class="form-item-right">
@Html.ValidationMessageFor(model => model.Email)
@Html.TextBoxFor(model => model.Email, new { @class = "textfield" })
@Html.LabelFor(model => model.Email, "Email Address")
</div>
<div class="form-item-right">
@Html.ValidationMessageFor(model => model.Password)
@Html.PasswordFor(model => model.Password, new { @class = "textfield" })
@Html.LabelFor(model => model.Password, "Password")
</div>
<div class="form-item-right">
@Html.ValidationMessageFor(model => model.ConfirmPassword)
@Html.PasswordFor(model => model.ConfirmPassword, new { @class = "textfield" })
@Html.LabelFor(model => model.ConfirmPassword, "Confirm")
</div>
<div class="form-item-right">
<input type="submit" value="Sign Up!" class="buttonSignUp"/>
</div>
}
Это приводит к разметке, как:
<span class="field-validation-valid" data-valmsg-for="FirstName" data-valmsg-replace="false">First Name is required.</span>
<input class="textfield" data-val="true" data-val-required="The FirstName field is required." id="FirstName" name="FirstName" value="" type="text">
<label for="FirstName">First Name</label>
Эти сценарии включены в представление макета:
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.6.4/jquery.min.js" type="text/javascript"></script>
<script src="@Url.Content("~/Scripts/jquery.validate.js")" type="text/javascript"></script>
<script src="@Url.Content("~/Scripts/jquery.validate.unobtrusive.js") "type="text/javascript"></script>
И это в web.config:
<add key="ClientValidationEnabled" value="true"/>
<add key="UnobtrusiveJavaScriptEnabled" value="true"/>
Код контроллера для полноты:
public ActionResult Candidate()
{
return View();
}
[HttpPost]
public ActionResult Candidate(RegisterModel model)
{
if (ModelState.IsValid)
{
//complete the registration
return View("Confirm", new ConfirmationModel { Email = model.Email, FirstName = model.FirstName });
}
else
{
return View(model);
}
}
Все результаты в представлении, которое не проверяет на стороне клиента. Форма сообщений без полей, введенных вообще. Проверка происходит только на сервере (который работает правильно FWIW).
В чем дело?
Изменить, чтобы включить результирующую разметку из представления.
1 ответ
Я не знаю, что вы делаете неправильно, но вот простые шаги, которые вы могли бы выполнить:
- Создайте новый проект ASP.NET MVC 3, используя шаблон по умолчанию
Определите следующую модель:
public class MyViewModel { [Required] public string Foo { get; set; } }
HomeController:
public class HomeController : Controller { public ActionResult Index() { return View(new MyViewModel()); } [HttpPost] public ActionResult Index(MyViewModel model) { return View(model); } }
Индекс просмотра:
@model MyViewModel <script src="@Url.Content("~/Scripts/jquery.validate.js")" type="text/javascript"></script> <script src="@Url.Content("~/Scripts/jquery.validate.unobtrusive.js")" type="text/javascript"></script> @using (Html.BeginForm()) { @Html.LabelFor(x => x.Foo) @Html.EditorFor(x => x.Foo) @Html.ValidationMessageFor(x => x.Foo) <button type="submit">OK</button> }
Выполните работу по проверке проекта => на стороне клиента и на стороне сервера, как ожидалось