ASP.NET MVC 5 ModelState.IsValid始终在MVC中返回false
我每次都面临ModelState.IsValid false。我调试了整个动作。当我展开ModelState错误部分时,我发现System.Web.Mvc.Model错误。在我的模型中,Status属性通过Data Annotation声明为Required。所以基本上这个错误表明我的状态在模型中是必需的。这就是为什么它给出验证错误。ASP.NET MVC 5 ModelState.IsValid始终在MVC中返回false
这是我的模型
public class CompanyResource
{
[Key]
public int Id { get; set; }
[Required]
[StringLength(100)]
public string Name { get; set; }
[StringLength(100)]
public string Position { get; set; }
[Display(Name="Date of Joining")]
public DateTime? DOJ { get; set; }
[StringLength(50)]
public string Phone { get; set; }
[StringLength(100)]
public string Address { get; set; }
[StringLength(1)]
[Required]
public string Status { get; set; }
public virtual ICollection<ProjectResource> ProjectResources { get; set; }
public virtual ICollection<ProjectSiteResource> ProjectSiteResources { get; set; }
}
}
这是我行动
[HttpPost]
[ValidateAntiForgeryToken]
public ActionResult Create([Bind(Include = "Id,Name,Position,DOJ,Phone,Address,Status")] CompanyResource companyResource)
{
var isAjaxRequest = Request.IsAjaxRequest();
ModelState["Status"].Errors.Clear();
if (ModelState.IsValid)
{
db.CompanyResource.Add(companyResource);
db.SaveChanges();
if (isAjaxRequest)
{
var staff = new SelectList(db.CompanyResource.ToList(), "Id", "Name");
return Json(new { Flag = true, CompanyResources = staff }, JsonRequestBehavior.AllowGet);
}
Success(string.Format("Successfully save data !"), true);
return RedirectToAction("Index");
}
if (!isAjaxRequest) return View(companyResource);
return Json(null, JsonRequestBehavior.AllowGet);
}
这是我在同一个控制器的另一种方法
public JsonResult GetStaff()
{
try
{
var staff = new SelectList(db.CompanyResource.ToList(), "Id", "Name");
return Json(new { Flag = true, CompanyResources = staff }, JsonRequestBehavior.AllowGet);
}
catch (Exception ex)
{
return Json(new { Flag = false, Msg = ex.Message }, JsonRequestBehavior.AllowGet);
}
}
这是我的查看
<div class="form-group">
@Html.Label("Status", htmlAttributes: new { @class = "control-label col-md-2", @required = "required" })
<div class="col-md-10">
<select class="form-control" id="Status">
<option value="A">Active</option>
<option value="I">Inactive</option>
</select>
</div>
</div>
在你的问题的评论表示您这是你的HTML和型号:
<select class="form-control" id="Status">
<option value="A">Active</option>
<option value="I">Inactive</option>
</select>
[StringLength(1)] [Required] public string Status { get; set; }
您需要设置选择标签的name
属性为MVC结合工作。所以加上这个名字是这样的:
<select class="form-control" id="Status" name="Status">
<option value="A">Active</option>
<option value="I">Inactive</option>
</select>
非常感谢。它工作得很好! :D – Nabid
很高兴工作。既然你是新手,请阅读[this](https://stackoverflow.com/help/someone-answers) – CodingYoshi
当然我会!我有另一个问题。提交表单时,最新的数据未在下拉列表中加载。下拉列表显示为空。但是当我刷新整个页面时,下拉框会加载该值,我可以看到我添加的最后一件事。我用ajax请求做了这个。调试整个解决方案,但没有得到一个错误。 – Nabid
你检查所有数据的注释......所有的人都需要有一个显示名称模型.. –
我检查。该属性设置为[必需]。 – Nabid
您是不是从UI填充状态值? –