ASP.NET MVC ValidationAttribute导致无效的客户端验证规则

时间:2015-06-30 09:12:11

标签: jquery asp.net-mvc jquery-validate data-annotations unobtrusive-validation

我正在研究ASP.NET MVC 5应用程序。我正在使用Attributes来验证我的模型(back-and frontend)。

我的一个模特有一个如下属性:

[Required( ... )]
[Range( 0d, Double.MaxValue, ...)]
public Decimal Amount { get; set; }

允许从 0 Double.MaxValue 的所有值作为金额。 (这在后端完美运行)

在我的用户界面中,我有一个此模型的表单:

@using (Html.BeginForm(null, null, FormMethod.Post))
{
    @* Anti Forgery Token *@
    @Html.AntiForgeryToken()
    <fieldset>
        ...
        <section>
            @Html.LabelFor(model => model.Amount, new { @class = "label" })
            <label class="input">
                @Html.EditorFor(model => model.Amount, new { htmlAttributes = new { placeholder = Resources.Amount } })
                @Html.RenderCombinedValidationMessages(x => x.Amount, false)
            </label>
        </section>
    </fieldset>
    @Html.RenderGlobalValidationMessages()
    <footer>
        <div class="btn-group">
            <a href="@Html.GetPreviousPage( Url.Action( "Index", "Controller" ) )" class="btn btn-default">@Resources.Back</a>
            <button type="submit" class="btn btn-primary">@Resources.Create</button>
        </div>
    </footer>
}

此代码创建如下所示的HTML:

<form action="/Controller/Create" class="smart-form" method="post" novalidate="novalidate">
    <fieldset>                                               
        <section>
            <label class="label" for="Amount">Amount</label>
            <label class="input">
                <input 
                    data-val="true" data-val-number="The field Amount must be a number." 
                    data-val-range="Amount must be between 0 and 1.79769313486232E+308." 
                    data-val-range-max="1.79769313486232E+308" 
                    data-val-range-min="0" 
                    data-val-required="Amount is required."
                    id="Amount" name="Amount" placeholder="Amount" type="text" value="">                
                <ul class="validationMessageList" data-property-name="Amount"></ul><span class="field-validation-valid" data-valmsg-for="Amount" data-valmsg-replace="true"></span>
            </label>
        </section>
    </fieldset>
    <footer>
        <div class="btn-group">
            <a href="http://localhost:26165/Controller/Create" class="btn btn-default">Back</a>
            <button type="submit" class="btn btn-primary">Create</button>
        </div>
    </footer>
</form>

现在出现问题:

根据验证属性,HtmlHelper为最大范围创建jQuery验证规则: data-val-range-max =“1.79769313486232E + 308”。这导致jQuery验证仅允许从0到1.79的值.... (小于2的值)

我该如何解决这个问题?

1 个答案:

答案 0 :(得分:2)

我知道的一种方式是:

      [Range(typeof(decimal), "0", "79228162514264337593543950335")]
      public decimal Amount { get; set; }

Meh-ish,但这是一个真实的交易。

十进制MaxValue为79228162514264337593543950335。https://msdn.microsoft.com/en-us/library/system.decimal.maxvalue(v=vs.110).aspx