2016-07-12 27 views
0

Ich kann nur nicht herausfinden, was falsch ist. Ich versuche Nein zu erlauben Null Werte zu Feld zu setzen, wenn Benutzer versucht, es zu tun, muss es zeigen Nachricht "*", und warten auf ihn, um Werte, aber es funktioniert nicht und Null-Werte erfolgreich an eine Aktion gesendet werden. Modell:Validierung funktioniert nicht mvc

public class CompanyMainInfoModel 
{ 
    public int CompanyId { get; set; } 

    [Required(ErrorMessage = "*")] 
    [Display(Name = "company_name", ResourceType = typeof(Localization))] 
    public string CompanyName { get; set; } 

    [Required(ErrorMessage = "*")] 
    [Display(Name = "company_address", ResourceType = typeof(Localization))] 
    public string CompanyAddress { get; set; } 

    [Required(ErrorMessage = "*")] 
    [Display(Name = "company_director", ResourceType = typeof(Localization))] 
    public string CompanyDirector { get; set; } 

    [Required(ErrorMessage = "*")] 
    [Display(Name = "company_phone", ResourceType = typeof(Localization))] 
    public string CompanyTelephoneNumber { get; set; } 
} 

Markup:

@model BTGHRM.Models.CompanyMainInfoModel 
@{ 
    Layout = "~/Views/Shared/_EmployeeMain.cshtml"; 
} 

<head> 
    <script src="~/Scripts/jquery-1.10.2.js"></script> 
    <script src="~/Scripts/jquery-ui.js"></script> 
    <script src="~/Scripts/jquery.validate.unobtrusive.js"></script> 
    <script src="~/Scripts/jquery.validate.js"></script> 
</head> 

<body> 

    <span class="content_h4">@Resources.Localization.company_info</span> 
    <br /> 
    <br /> 

    <div id="FormContainer"> 
     @Html.Partial("Partial/_CompanyInfo", Model) 
    </div> 


</body> 

Teil Markup:

@model BTGHRM.Models.CompanyMainInfoModel 

@using (Html.BeginForm("CompanyInfo", "Administration")) 
{ 
    <table> 
     <tr> 
      <td>@Html.LabelFor(m => m.CompanyName)</td> 
      <td>@Html.TextBoxFor(m => m.CompanyName)</td> 
      <td>@Html.ValidationMessageFor(m => m.CompanyName, "" , new { @class="text-danger"})</td> 
     </tr> 
     <tr> 
      <td>@Html.LabelFor(m => m.CompanyAddress)</td> 
      <td>@Html.TextBoxFor(m => m.CompanyAddress)</td> 
      <td>@Html.ValidationMessageFor(m => m.CompanyAddress, "", new { @class = "text-danger" })</td> 
     </tr> 
     <tr> 
      <td>@Html.LabelFor(m => m.CompanyDirector)</td> 
      <td>@Html.TextBoxFor(m => m.CompanyDirector)</td> 
      <td>@Html.ValidationMessageFor(m => m.CompanyDirector, "", new { @class = "text-danger" })</td> 
     </tr> 
     <tr> 
      <td>@Html.LabelFor(m => m.CompanyTelephoneNumber)</td> 
      <td>@Html.TextBoxFor(m => m.CompanyTelephoneNumber)</td> 
      <td>@Html.ValidationMessageFor(m => m.CompanyTelephoneNumber, "", new { @class = "text-danger" })</td> 
     </tr> 
    </table> 
    <input style="width:78px" type="submit" [email protected] /> 
} 

Und trotz [Erforderlich] es erlaubt mir noch NULL-Werte in jedem Feld zu setzen. Was ist falsch an meinem Code?

+0

Haben Sie die relevanten scr In der Ansicht? –

+0

ja, und die [erforderlich] funktioniert auf anderen Seiten, außer diesem. – GeekyNuns

+0

Ihre Skripte sind in der falschen Reihenfolge. 'jquery' muss zuerst sein (vor' jquery.validate' und 'jquery.validate.unobtrusive') –

Antwort

2

Sie müssen unaufdringlich Skripte haben in Web-Config Sie

<add key="UnobtrusiveJavaScriptEnabled" value="true"/> 

Dann

  • jquery
  • jquery.validate.js
  • jquery.validate.unobtrusive hinzufügen müssen aktiviert. js
2

Sie müssen "jquery.validate.js" und "jquery.validate.unobtrusive.js" in Ihrer Ansicht hinzufügen. Die Validierung benötigt die beiden oben genannten Dateien zusammen mit "Jquery.js". Hoffe das hilft.

Verwandte Themen