ASP.NET MVC 5 ModelState.IsValid始终在MVC中返回false

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> 
+0

你检查所有数据的注释......所有的人都需要有一个显示名称模型.. –

+0

我检查。该属性设置为[必需]。 – Nabid

+0

您是不是从UI填充状态值? –

在你的问题的评论表示您这是你的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> 
+0

非常感谢。它工作得很好! :D – Nabid

+0

很高兴工作。既然你是新手,请阅读[this](https://stackoverflow.com/help/someone-answers) – CodingYoshi

+0

当然我会!我有另一个问题。提交表单时,最新的数据未在下拉列表中加载。下拉列表显示为空。但是当我刷新整个页面时,下拉框会加载该值,我可以看到我添加的最后一件事。我用ajax请求做了这个。调试整个解决方案,但没有得到一个错误。 – Nabid