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 isttext
und wenn ich meine ändereTextBoxFor
zuEditorFor
es verändert sich zunumber
aber ich sehe immer noch das gleiche Verhalten.