【问题标题】:Asp Mvc3 webgrid Paging and Filtering by ajaxAsp Mvc3 webgrid分页和ajax过滤
【发布时间】:2012-02-15 11:12:03
【问题描述】:

我对 Asp.Net MVC3 的 WebGrid 控件有一点问题。我想要的是使用 ajax 和 webgrid 执行搜索视图;像这样:

搜索条件_____________ em>_________________强>

主题:_____

任务类型:_____

提交搜索


带有分页的WebGrid

.

当我单击按钮搜索时,它会通过 ajax 调用 HTTPost 操作并应用搜索条件;但是,当我尝试进行分页时,它会转到 HTTPGet 操作;这样,根据搜索条件的过滤器就不会执行了。

我将网格放在局部视图中;有代码:

    @model IEnumerable<MVC3.Models.Task>
@{
    var grid = new WebGrid(null, rowsPerPage: 2, canPage: true, canSort: true, ajaxUpdateContainerId: "myGrid");
    grid.Bind(Model, rowCount: 3, autoSortAndPage: true);
    grid.Pager(mode: WebGridPagerModes.All);
    @grid.GetHtml(
    columns: grid.Columns(
            grid.Column(format: (item) => Html.ActionLink("Assign Notifications", "AssignNotifications", new { id = item.TaskId })),
            grid.Column(format: (item) => Html.ActionLink("Edit", "Edit", new { id = item.TaskId })),
            grid.Column(format: (item) => Html.ActionLink("Delete", "Delete", new { id = item.TaskId })),
            grid.Column("Subject"),
            grid.Column("Comment"),
            grid.Column(columnName: "Status", header: "Status", format: (item) => item.TaskStatu.Name),
            grid.Column(columnName: "StartDate", header: "Start Date", format: (item) => item.StartDate.ToString("MM/dd/yyy")),
            grid.Column(columnName: "Deadline", header: "Dead Line", format: (item) => item.Deadline.ToString("MM/dd/yyy"))
            )
    );
}

我的索引视图看起来像:

@model MVC3.ViewModel.TaskSearchViewModel
@{
    ViewBag.Title = "Index";
    Layout = "~/Views/Shared/_Layout.cshtml";
}
<h2>
    Task Index</h2>
<hr />
@using (Ajax.BeginForm(new AjaxOptions { InsertionMode = InsertionMode.Replace, UpdateTargetId = "myGrid" }))
{
    <div id="Filters">
        <fieldset>
            <legend>Search criteria</legend>
            <br />
            <table>
                <tr>
                    <td>
                        @Html.LabelFor(x => x.Subject)
                    </td>
                    <td>
                        @Html.TextBoxFor(x => x.Subject, new { style = "width: 255px;" })
                    </td>
                </tr>
                <tr>
                    <td>
                        @Html.LabelFor(x => x.TaskTypeId)
                    </td>
                    <td>
                        @Html.DropDownListFor(x => x.TaskTypeId, Model.GetTaskTypesSelectList(), "Select", new { style = "width: 260px;" })
                    </td>
                </tr>
                <tr>
                    <td>
                        @Html.LabelFor(x => x.ResponsableId)
                    </td>
                    <td>
                        @Html.DropDownListFor(x => x.ResponsableId, Model.GetResponsablesSelectList(), "Select", new { style = "width: 260px;" })
                    </td>
                </tr>
                <tr>
                    <td>
                        @Html.LabelFor(x => x.StatusId)
                    </td>
                    <td>
                        @Html.DropDownListFor(x => x.StatusId, Model.GetStatusSelectList(), "Select", new { style = "width: 260px;" })
                    </td>
                </tr>
            </table>
        </fieldset>
    </div>
    @Html.Hidden("page")
    <input id="btnSearch" type="submit" value="Search" />
}
<br />
<div id="myGrid">
    @Html.Partial("_TaskSearchResult", Model.ResultTask)
</div>
<br />
@Html.ActionLink("Create new Task", "NewTask")

如果有人知道如何解决我的问题,我将不胜感激。

问候 阿图罗

【问题讨论】:

标签: ajax asp.net-mvc asp.net-mvc-3 razor webgrid


【解决方案1】:

看到网格会为每个分页器项目(和列标题)生成一个 onclick 调用,难道您不能使用 jQuery 将默认值替换为调用传递回表单的 Ajax 方法吗?

【讨论】:

    【解决方案2】:

    我认为这是因为您每次单击下一页链接时都会替换网格。也许像这样使用它:

    @model IEnumerable<MVC3.Models.Task>
    @{
        var grid = new WebGrid(null, rowsPerPage: 2, canPage: true, canSort: true, ajaxUpdateContainerId: "myGrid");
        grid.Bind(Model, rowCount: 3, autoSortAndPage: true);
        grid.Pager(mode: WebGridPagerModes.All);
    <div id="myGrid">
        @grid.GetHtml(
        columns: grid.Columns(
                grid.Column(format: (item) => Html.ActionLink("Assign Notifications", "AssignNotifications", new { id = item.TaskId })),
                grid.Column(format: (item) => Html.ActionLink("Edit", "Edit", new { id = item.TaskId })),
                grid.Column(format: (item) => Html.ActionLink("Delete", "Delete", new { id = item.TaskId })),
                grid.Column("Subject"),
                grid.Column("Comment"),
                grid.Column(columnName: "Status", header: "Status", format: (item) => item.TaskStatu.Name),
                grid.Column(columnName: "StartDate", header: "Start Date", format: (item) => item.StartDate.ToString("MM/dd/yyy")),
                grid.Column(columnName: "Deadline", header: "Dead Line", format: (item) => item.Deadline.ToString("MM/dd/yyy"))
                )
        );
    </div>
    }
    

    【讨论】:

    • 我不明白这将如何帮助传递过滤条件?网格生成要调用的 URL,其中包括排序列、排序方向和页码(如果是寻呼机),因此您需要以某种方式对其进行扩充。
    猜你喜欢
    • 2012-03-03
    • 2013-10-09
    • 2011-12-15
    • 2011-09-14
    • 1970-01-01
    • 2012-01-12
    • 1970-01-01
    • 2012-05-02
    • 2012-07-28
    相关资源
    最近更新 更多