Asp.net mvc 在未显示任何验证消息的区域中提交表单后?
我有一个区域,在这个区域我有一个PostController,一个为GET方法添加名称的操作和一个为POST方法添加名称的操作,在提交表单后,我将错误添加到modelstate,但在回发后,没有显示任何验证消息和staus代码:301永久移动 我的viewmodel:Asp.net mvc 在未显示任何验证消息的区域中提交表单后?,asp.net-mvc,asp.net-mvc-4,validation,Asp.net Mvc,Asp.net Mvc 4,Validation,我有一个区域,在这个区域我有一个PostController,一个为GET方法添加名称的操作和一个为POST方法添加名称的操作,在提交表单后,我将错误添加到modelstate,但在回发后,没有显示任何验证消息和staus代码:301永久移动 我的viewmodel: public class NewPostViewModel { [Required(ErrorMessage = "Please enter title.")] public string Title { get
public class NewPostViewModel
{
[Required(ErrorMessage = "Please enter title.")]
public string Title { get; set; }
[AllowHtml]
[Required(ErrorMessage = "Please enter article content.")]
public string Content { get; set; }
[Required(ErrorMessage = "Please enter a tag.")]
public string Tags { get; set; }
public bool PublishNow { get; set; }
public string PublishDate { get; set; }
public string PublishTime { get; set; }
}
我的看法是:
@model Soleimanzadeh.Models.ViewModels.NewPostViewModel
@{
ViewBag.Title = "Add";
Layout = MVC.Admin.Shared.Views.BaseLayout;
}
@using (Html.BeginForm(MVC.Admin.Post.Add(), FormMethod.Post))
{
@Html.AntiForgeryToken()
@Html.ValidationSummary(false, null, new { @class = "alert" })
<div class="row-fluid">
<div class="span9">
<div class="row-fluid">
<div class="span8">
@Html.TextBoxFor(np => np.Title, new { @class = "span12", placeholder = "Title" })
@Html.ValidationMessageFor(model=>model.Title)
</div>
</div>
<div class="row-fluid">
<div class="span12">
@Html.TextAreaFor(np => np.Content)
@Html.ValidationMessageFor(model=>model.Content)
</div>
</div>
</div>
<div class="span3">
<div class="row-fluid">
<div class="post-options-container">
<div class="header">
Tags
</div>
<div class="content">
<input type="text" placeholder="tags" class="tagManager" style="width: 100px;" />
</div>
</div>
</div>
<div class="row-fluid">
<div class="post-options-container">
<div class="header">
Status
</div>
<div class="content">
<label class="checkbox">
@Html.CheckBoxFor(np => np.PublishNow)
Publish Now?
</label>
<div>
Publish Date:
@Html.TextBoxFor(np => np.PublishDate, new { @class = "calcInput" })
</div>
<div>
Publish Time:
@Html.TextBoxFor(np => np.PublishTime, new { @class = "timeInput" })
</div>
<div>
<input type="submit" value="Save"/>
</div>
</div>
</div>
</div>
</div>
</div>
}
@*some scripts here*@
我还使用html编辑器来编辑内容
解决方案:
我用于将URL转换为小写,但我没有在区域部分启用此工具,并在提交表单后重定向页面。请发布您的控制器和视图。我看不到您的代码有任何错误。这个“警报”css类怎么样?它会以某种方式隐藏验证摘要吗?另外,我在这里发现了一个类似的问题,解决它的是清洁和重建解决方案。我找到了解决方案,请阅读,非常感谢。
public partial class PostController : Controller
{
public virtual ActionResult Add()
{
var newPost = new NewPostViewModel();
return View(MVC.Admin.Post.Views.Add, newPost);
}
[HttpPost]
[ValidateAntiForgeryToken]
public virtual ActionResult Add(NewPostViewModel post)
{
ModelState.AddModelError("Content","Wrong");
return this.View(MVC.Admin.Post.Views.Add, post);
}
}