вспомогательный тэг asp-route- не работает - Razor Pages (.Net Core 3 превью 5) - PullRequest
1 голос
/ 19 июня 2019

Я новичок в Razor Pages, так что, возможно, я делаю это просто неправильно. Я использую .Net Core 3 preview 5 и по какой-то причине мой параметр asp-route не работает.

На моей странице cshtml (index) есть следующая кнопка:

<form method="get" asp-page-handler="RetrieveData" asp-route-retrieveid="5">
    <button class="btn btn-primary">Retrieve Data</button>
</form>

Мой код для этого действия:

public async Task<IActionResult> OnGetRetrieveData(int retrieveid)
{
    // Do stuff
    return Page();
}

Каждый раз, когда я нажимаю кнопку, параметр retrieveid остается равным 0 (null): enter image description here

Весь мой cshtml-код:

@page "{handler?}"
@model IndexModel
@{
    ViewData["Title"] = "Retrieve Data";
}

@section Scripts
{
    <script type="text/javascript">
        // Some jQuery
    </script>
}


<div class="text-center">
    <h1 class="display-4">Retrieve Data</h1>
</div>



@if (Model.ErrorMessage != null)
{
    <div id="ErrorMsg" class="alert alert-info alert-dismissible fade show" role="alert">
        @Model.ErrorMessage
        <button type="button" class="accept-policy close" data-dismiss="alert" aria-label="Close" data-cookie-string="@Model.ErrorMessage">
            <span aria-hidden="true">Sluiten</span>
        </button>
    </div>
}



<button id="getData" class="btn btn-primary" data-toggle="modal" data-target="#modalGetDataConfirm">
    Get Data
</button>



<!-- Modal -->
<div id="modalGetDataConfirm" class="modal fade" role="dialog">
    <div class="modal-dialog">

        <!-- Modal content-->
        <div class="modal-content">
            <div class="modal-header">
                <h4 class="modal-title">Get Data</h4>
                <button type="button" class="close" data-dismiss="modal">&times;</button>
            </div>

            <div class="modal-body">
                <p>Do you want to retrieve the data</p>
            </div>

            <div class="modal-footer">
                <form method="get" asp-page-handler="RetrieveData" asp-route-retrieveid="5">
                    <button class="btn btn-primary">Retrieve Data</button>
                </form>
                <button type="button" class="btn btn-secondary" data-dismiss="modal">Cancel</button>
            </div>
        </div>
    </div>
</div>



<br />


@if (Model.DataModel != null)
{

    // table with search and the retrieved data


    var prevDisabled = !Model.DataModel.HasPreviousPage ? "disabled" : "";
    var nextDisabled = !Model.DataModel.HasNextPage ? "disabled" : "";

    <a asp-page-handler="LoadData"
       asp-route-sortOrder="@Model.CurrentSort"
       asp-route-pageIndex="@(Model.DataModel.PageIndex - 1)"
       asp-route-currentFilter="@Model.CurrentFilter"
       class="btn btn-default @prevDisabled">
        Vorige
    </a>
    <a asp-page-handler="LoadData"
       asp-route-sortOrder="@Model.CurrentSort"
       asp-route-pageIndex="@(Model.DataModel.PageIndex + 1)"
       asp-route-currentFilter="@Model.CurrentFilter"
       class="btn btn-default @nextDisabled">
        Volgende
    </a>

}

Странно то, что значения asp-route в элементе подкачки <a> работают ..

1 Ответ

0 голосов
/ 19 июня 2019

Вам необходимо добавить параметр в шаблон маршрута:

@page "{handler?}/{id?}"
@model IndexModel
@{
    ViewData["Title"] = "Retrieve Data";
}
...
...