Die Bereichsüberprüfung für MVC-Datenanmerkungen funktioniert nicht ordnungsgemäß

Ich habe einRangeValidator auf eine Eigenschaft in meinem Modell, um nur Ganzzahlen zwischen 0 und 100 zuzulassen. Ich habe eine Teilansicht, in der ein Formular zum Aktualisieren der Eigenschaft über ein Dialogfeld der jQuery-Benutzeroberfläche angezeigt wird. Ich habe mir die Quelle angesehen und kann bestätigen, dass die Datenanmerkungsattribute ordnungsgemäß generiert werden. Die Validierung funktioniert jedoch nicht ordnungsgemäß. Es wird zwar eine Art Validierung durchgeführt, der von mir festgelegte Bereich wird jedoch nicht verwendet. Die Werte 1, 10 und 100 erzeugen den Fehler nicht. Jeder andere ein- oder zweistellige Wert erzeugt den Fehler. Wenn ich jedoch mit Nullen auffülle, sind alle Werte unter einhundert in Ordnung.

Modell:

public class MyModel
{
  ...
  [Required(ErrorMessage = "{0} is required")]
  [Range(typeof(int), "0", "100", 
         ErrorMessage = "{0} can only be between {1} and {2}")]
  public int Percentage { get; set; }
  ...
}

Teilansicht:

@model MyApp.Models.Partials.MyModel

<div id="myDialog" class="editModal" title="Update Percentage">
  @using (Ajax.BeginForm("UpdatePercentage", "MyController", 
                         new AjaxOptions() { HttpMethod = "Post", 
                                             OnSuccess = "onUpdateSuccess" }, 
                         new { name = "myForm" }))
  {
    @Html.ValidationSummary(null, new { style = "width:auto;max-width:22em;               
                                                 float:left;clear:both;" })    
    <div style="width:auto;float:left;clear:both;">
      <div style="width:10em;float: left;text-align:right;clear:left;">
        @Html.Label("Percentage:")
      </div>
      <div style="width:12em;margin-left:1em;float:left;clear:right;">
        @Html.TextBoxFor(m => m.Percentage)
      </div>
    </div>
    <div style="width:23em;clear:both;text-align:center;">
      <hr />
      <input type="button" value="Cancel" class="cancelModalButton" 
             data-modal="myDialog" />
      <input type="submit" value="Submit" class="submitModalButton" 
             data-modal="myDialog" data-form="myForm" />
    </div>
  }
</div>

Markup produziert:

<div id="myDialog" class="editModal" title="Update Percentage">
  <form action="/Web/MyController/UpdatePercentage?Length=3" 
        data-ajax="true" data-ajax-method="Post" data-ajax-success="onUpdateSuccess" 
        id="form2" method="post" name="myForm">
    <div class="validation-summary-valid" data-valmsg-summary="true" 
         style="width:auto;max-width:22em;float:left;clear:both;">
      <ul>
        <li style="display:none"></li>
     </ul>
    </div>
    <div style="width:auto;float:left;clear:both;margin-bottom:.75em;">
      <div style="width:10em;float: left;text-align:right;clear:left;">
        <label for="Percentage:">Percentage:</label>
      </div>
      <div style="width:12em;margin-left:1em;float:left;clear:right;">
        <input data-val="true" data-val-number="The field Percentage must be a number." 
               data-val-range="Percentage can only be between 0 and 100" 
               data-val-range-max="100" data-val-range-min="0" 
               data-val-required="Percentage is required" id="Percentage" 
               name="Percentage" type="text" value="10" />
      </div>
    </div>
    <div style="width:23em;clear:both;text-align:center;">
      <hr />
      <input type="button" value="Cancel" class="cancelModalButton" data-modal="myDialog" />
      <input type="submit" value="Submit" class="submitModalButton" data-modal="myDialog" data-form="myForm" />
    </div>
  </form>
</div>

Ich sehe, dass der Typ auf eingestellt isttextund wenn ich meine ändereTextBoxFor zuEditorFor es verändert sich zunumber aber ich sehe immer noch das gleiche Verhalten.

Antworten auf die Frage(2)

Ihre Antwort auf die Frage