首页 文章

在asp.net核心剃刀页面中进行排序和过滤

提问于
浏览
0

我正在使用Microsoft文档中的ASP.NET Core教程中的数据, (Sort, filter, page, and group section) 但我很难弄清楚以下代码是如何工作的...(我是razor pages和asp.net core的新手) .

这是学生索引页面的PageModel .

namespace Contoso.Pages.Students
{
    public class IndexModel : PageModel
    {
       //

        public string NameSort { get; set; }
        public string DateSort { get; set; }
        public string CurrentFilter { get; set; }
        public string CurrentSort { get; set; }


        public async Task OnGetAsync(string sortOrder,string currentFilter, string searchString, int? pageIndex)
        {
            CurrentSort = sortOrder;
            NameSort = String.IsNullOrEmpty(sortOrder) ? "name_desc" : "";
            DateSort = sortOrder == "Date" ? "date_desc" : "Date";
            if (searchString != null)
            {
                pageIndex = 1;
            }
            else
            {
                searchString = currentFilter;
            }

            CurrentFilter = searchString;

            IQueryable<Student> studentIQ = from s in _context.Students
                                            select s;
            if (!String.IsNullOrEmpty(searchString))
            {
                studentIQ = studentIQ.Where(s => s.LastName.Contains(searchString)
                                       || s.FirstMidName.Contains(searchString));
            }
            switch (sortOrder)
            {
                case "name_desc":
                    studentIQ = studentIQ.OrderByDescending(s => s.LastName);
                    break;
                case "Date":
                    studentIQ = studentIQ.OrderBy(s => s.EnrollmentDate);
                    break;
                case "date_desc":
                    studentIQ = studentIQ.OrderByDescending(s => s.EnrollmentDate);
                    break;
                default:
                    studentIQ = studentIQ.OrderBy(s => s.LastName);
                    break;
            }

        }
    }
}

这是模型的索引页面中的from .

@*other markup commented out*@
<table class="table">
    <thead>
        <tr>
            <th>
                <a asp-page="./Index" asp-route-sortOrder="@Model.NameSort"
                   asp-route-currentFilter="@Model.CurrentFilter">
                    @Html.DisplayNameFor(model => model.Student[0].LastName)
                </a>
            </th>
            <th>
                @Html.DisplayNameFor(model => model.Student[0].FirstMidName)
            </th>
            <th>
                <a asp-page="./Index" asp-route-sortOrder="@Model.DateSort"
                   asp-route-currentFilter="@Model.CurrentFilter">
                    @Html.DisplayNameFor(model => model.Student[0].EnrollmentDate)
                </a>
            </th>
            <th></th>
        </tr>
    </thead>
</table>

@*other markup commented out*@

现在我的问题是如何 asp-route-sortOrder="@Model.NameSort"OnGetAsync 方法中的 sortOrder 参数相关?以及如何通过单击索引页面中的链接来设置值 sortOrder 究竟是什么?

1 回答

  • 0

    如何在OnGetAsync方法中与sortOrder参数相关的asp-route-sortOrder =“@ Model.NameSort”?

    select标记帮助程序上的 route 属性允许您指定路径数据参数的值 . 如果密钥(在这种情况下为 sortOrder )作为路径模板的一部分包含在内,则该值将在生成的URL中显示为段 . 否则,它将作为查询字符串值附加到URL . 这些与Model Binding的处理程序方法相匹配 . 您可以在此处阅读有关模型绑定如何在Razor页面中工作的更多信息:https://www.learnrazorpages.com/razor-pages/model-binding

相关问题