RazorPages Page Remote 不适用于模型

Jac*_*kal 6 c# razor remote-validation asp.net-core razor-pages

根据https://www.mikesdotnetting.com/article/343/improved-remote-validation-in-razor-pages 我按照教程并实施了 PageRemote。但是,如果应用于模型的属性并且我将模型用作属性,则它不起作用。

public class Draft
{
    public int Id { get; set; }
    [PageRemote(ErrorMessage = "Invalid data", AdditionalFields = "__RequestVerificationToken", HttpMethod = "post", PageHandler = "CheckReference")]
    public string Reference { get; set; }

}

[BindProperty]
public Draft Draft { get; set; }

public JsonResult OnPostCheckReference()
{            
    var valid = !Draft.Reference.Contains("12345");
    return new JsonResult(valid);
}
Run Code Online (Sandbox Code Playgroud)

在我的页面上

<tab>
    <tab-item icon="fas fa-arrow-left" url="@Url.Page("../Index")"></tab-item>
    <tab-item icon="fas fa-list" url="@Url.Page("Index")"></tab-item>
    <tab-item icon="fas fa-plus" is-active="true"></tab-item>
</tab>
<form method="post">
    <card>
        <card-header icon="fas fa-plus" title="Draft"></card-header>
        <card-body>

            <input asp-for="Draft.Reference" />
            <span asp-validation-for="Draft.Reference" class="text-danger"></span>

        </card-body>
        <card-footer>
            <button class="btn btn-success"><i class="fas fa-plus"></i> Adicionar </button>
        </card-footer>
    </card>
</form>
@section Scripts{

    @{ await Html.RenderPartialAsync("_ValidationScriptsPartial"); }
    <script src="~/lib/jquery-ajax-unobtrusive/dist/jquery.unobtrusive-ajax.min.js"></script>

}
Run Code Online (Sandbox Code Playgroud)

Dan*_*ach 5

对嵌套模型属性的远程验证不允许您在父对象上指定其他字段。__RequestVerificationToken始终位于模型的根部。jquery.validate.unobtrusive.js的源正在查找前缀为 的字段*.,并将模型名称作为前缀。标签asp-for助手正在添加*.到字段的开头。

*.您可以通过在 html 中手动指定属性并从属性中删除 AnotherFields 来规避此前缀。

页面远程属性:

public class Draft
{
    public int Id { get; set; }
    [PageRemote(ErrorMessage = "Invalid data", HttpMethod = "post", PageHandler = "CheckReference")]
    public string Reference { get; set; }

}
Run Code Online (Sandbox Code Playgroud)

网页:

<input asp-for="Reference" data-val-remote-additionalfields="__RequestVerificationToken" />

Run Code Online (Sandbox Code Playgroud)


Mik*_*ind 4

对嵌套模型属性的远程验证并不简单。框架在所有附加字段中添加模型名称作为前缀,因此请求验证失败,导致 400 错误。

解决方法是将要远程验证的字段与子模型分开,并使其成为 PageModel 的第一类属性。然后,如果 ModelState 有效,则将该值分配给嵌套模型。

public class Draft
{
    public int Id { get; set; }

    public string Reference { get; set; }

}

[BindProperty]
public Draft Draft { get; set; }

[BindProperty, PageRemote(ErrorMessage = "Invalid data", AdditionalFields = "__RequestVerificationToken", HttpMethod = "post", PageHandler = "CheckReference")]
public string Reference {get;set;}

public JsonResult OnPostCheckReference()
{            
    var valid = !Reference.Contains("12345");
    return new JsonResult(valid);
}
Run Code Online (Sandbox Code Playgroud)

然后采用以下形式:

<input asp-for="Reference" />
<span asp-validation-for="Reference" class="text-danger"></span>
Run Code Online (Sandbox Code Playgroud)