【发布时间】:2011-06-22 02:13:35
【问题描述】:
我在 asp.net mvc3 应用程序中的客户端验证有问题。
我的代码看起来:
function loadEditCategoryDialog(categoryId) {
$.ajax({
url : "/rovastamp3/Admin/CategoryEditDialog",
data : "categoryId="+categoryId,
success : function(data){
$("#popup_dialog").html(data);
$("#popup_dialog").dialog({
modal: true,
draggable: false,
resizable: false,
title: "Upravit kategorii",
width: 600,
height: 500,
});
}
});
}
控制器:
[HttpGet]
public ActionResult CategoryEditDialog(int categoryId)
{
CategoryEditViewModel categoryEditViewModel = new CategoryEditViewModel();
categoryEditViewModel.Category = _postAuctionCategoryRepo.Query()
.SingleOrDefault(x => x.Id == categoryId);
return PartialView(categoryEditViewModel);
}
[HttpPost]
public ActionResult CreateNewCategory(CategoryEditViewModel categoryEditViewModel)
{
if (ModelState.IsValid)
{
return RedirectToAction("Index");
}
return View("CategoryEditDialog", categoryEditViewModel);
}
最后是我的部分观点:
@model Rovastamp.MVC3.ViewModels.AdminController.CategoryEditViewModel
<h2>Upravit kategorii @Model.Category.Name</h2>
@{Html.EnableClientValidation();}
@using (Html.BeginForm("CreateNewCategory", "Admin"))
{
@Html.ValidationSummary(true)
<fieldset>
<legend>Objednávkový formulář</legend>
<div class="editor-label">
@Html.LabelFor(model => model.Category.Name)
</div>
<div class="editor-field">
@Html.TextBoxFor(model => model.Category.Name)
@Html.ValidationMessageFor(model => model.Category.Name)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.Category.Position)
</div>
<div class="editor-field">
@Html.TextBoxFor(model => model.Category.Position)
@Html.ValidationMessageFor(model => model.Category.Position)
</div>
<input type="submit" value="Upravit" class="submit_button" />
</fieldset>
}
在我的 web.config 中,我打开了 UnobtrusiveJavaScript 和 ClientValidatin 应用设置。
如果我点击 jquery ui 对话框上的提交按钮,mvc 会在没有客户端验证的情况下完全刷新?
问题出在哪里?
感谢您的帮助
编辑:
在我的布局页面中,我包含以下脚本:
- jquery.unobtrusive-ajax.js
- jquery.validate.js
- jquery.validate.unobtrusive.js
编辑 2
在我的例子中我放了:
jQuery.validator.unobtrusive.parse('#popup_dialog');
在我调用 jquery ui 对话框和客户端验证之前完美运行。
【问题讨论】:
标签: asp.net-mvc validation jquery-ui dialog