Kendo Grid MVC 默認(rèn)Page,F(xiàn)ilter綁定

項(xiàng)目有一個(gè)需求,需要將Grid的分頁(yè),排序,過濾信息保存下來(lái),并且在跳轉(zhuǎn)到該功能時(shí)自動(dòng)應(yīng)用
實(shí)現(xiàn)方式

// Action
 public IActionResult Index([DataSourceRequest] DataSourceRequest request)
 {
     ViewData["returnUrl"] = Request.GetEncodedUrl();
     return View(request);
 }

// extensions
public static GridBuilder<TModel> Init<TModel>(this GridBuilder<TModel> builder, DataSourceRequest request)
    where TModel : class
{
    var component = builder.ToComponent();
    var dataSource = component.DataSource;

    if (request != null)
    {
        dataSource.PageSize = request.PageSize > 0 ? request.PageSize : 20;
        dataSource.Page = request.Page;
        dataSource.GroupPaging = request.GroupPaging;

        if (request.Filters != null)
        {
            dataSource.Filters.AddRange(request.Filters);
        }

        if (request.Sorts != null)
        {
            dataSource.OrderBy.AddRange(request.Sorts);
        }
    }
    else
    {
        dataSource.PageSize = 20;
    }

    return builder;
}

// cshtml
@(
    Html.Kendo().Grid<VM>().Init(Model)
    )

<script>
    function getNewUrl(event) {
        event.preventDefault();
        var url = new URL(document.location.href);
        var grid = $('#gridId').data("kendoGrid")
        if (grid) {
            var dataSource = grid.dataSource;
            var options = dataSource.transport.setup({
                data: {
                    page: dataSource.page(),
                    pageSize: dataSource.pageSize(),
                    sort: dataSource.sort(),
                    filter: dataSource.filter(),
                    group: dataSource.group()
                }
            }, "read")
            var data = options.data;
            url.searchParams.set("page", encodeURIComponent(data.page));
            url.searchParams.set("pageSize", encodeURIComponent(data.pageSize));
            url.searchParams.set("sort", encodeURIComponent(data.sort || ""));
            url.searchParams.set("filter", encodeURIComponent(data.filter || ""));
            url.searchParams.set("group", encodeURIComponent(data.group || ""));
        }

        return url.pathname + url.search;
    }
</script>
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語(yǔ)法,類相關(guān)的語(yǔ)法,內(nèi)部類的語(yǔ)法,繼承相關(guān)的語(yǔ)法,異常的語(yǔ)法,線程的語(yǔ)...
    子非魚_t_閱讀 34,805評(píng)論 18 399
  • 一. Java基礎(chǔ)部分.................................................
    wy_sure閱讀 4,030評(píng)論 0 11
  • 1.ios高性能編程 (1).內(nèi)層 最小的內(nèi)層平均值和峰值(2).耗電量 高效的算法和數(shù)據(jù)結(jié)構(gòu)(3).初始化時(shí)...
    歐辰_OSR閱讀 30,271評(píng)論 8 265
  • Swift1> Swift和OC的區(qū)別1.1> Swift沒有地址/指針的概念1.2> 泛型1.3> 類型嚴(yán)謹(jǐn) 對(duì)...
    cosWriter閱讀 11,679評(píng)論 1 32
  • Spring Web MVC Spring Web MVC 是包含在 Spring 框架中的 Web 框架,建立于...
    Hsinwong閱讀 22,966評(píng)論 1 92

友情鏈接更多精彩內(nèi)容