使用两个提交按钮进行不显眼的验证,而不对其进行验证

时间:2016-01-19 17:04:20

标签: jquery asp.net-mvc-5 unobtrusive-validation

我目前有一个使用MVC 5的表单,其中有两个提交/发布按钮 - 一个用于完成表单(在其他验证中验证必填字段),另一个用于保存表单(不需要真正的验证)。它工作正常,但不包括不显眼的验证,但我想使用它...当我这样做时,终结按钮工作正常,但保存按钮就好像它是最终确定按钮 - 验证字段时它不应该是

有没有办法让这成为可能?

以下是代码段。

查看

{BeginForm code goes here}
@Html.LabelFor(model => model.TotalHours)
@Html.TextBoxFor(model => model.TotalHours)
@Html.ValidationMessageFor(model => model.TotalHours)
...
<input type="submit" value="Finalize" name="btnCreate" />
<input type="submit" value="Save and Quit" name="btnCreate" />

型号(使用EF)

[Required(ErrorMessage = "Please enter the total number of hours.")]
[Display(Name = "Total Hours")]
public Nullable<decimal> TotalHours { get; set; }

控制器

[ValidateAntiForgeryToken]
[HttpPost]
[MultiBtn(Name = "btnCreate", Argument = "Finalize")]
public async Task<ActionResult> CreateFinalize(FormObj oForm)
{
    using (var dbContext = new DBContext())
    {
        if (ModelState.IsValid) { ... }
        else { return View(oForm); }
    }
}
[ValidateAntiForgeryToken]
[HttpPost]
[MultiBtn(Name = "btnCreate", Argument = "Save and Quit")]
public async Task<ActionResult> CreateFinalize(FormObj oForm)
{
    using (var dbContext = new DBContext())
    {
        // Remove model errors
        foreach (var modelStateVals in ModelState.Values)
            modelStateVals.Errors.Clear();
        // Process the form and save here
    }
}

1 个答案:

答案 0 :(得分:0)

我发现你可以添加html中的内容:

<input class="cancel" />

不幸的是,取消类已被弃用。但现在它使用了 formnovalidate ,这就是我所需要的。