Asp Mvc3 webgrid通过ajax进行分页和过滤
发布时间:2020-12-16 09:36:10 所属栏目:asp.Net 来源:网络整理
导读:我对Asp.Net MVC3的WebGrid控件有一点问题.我想要的是使用ajax和webgrid执行搜索视图;这样的事情: 搜索条件 ______________________________ 学科: _____ 任务类型:_____ 提交搜索 WebGrid withPaging . 当我点击按钮搜索时,它会通过ajax调用HTTPost操作
我对Asp.Net MVC3的WebGrid控件有一点问题.我想要的是使用ajax和webgrid执行搜索视图;这样的事情:
搜索条件 ______________________________ 学科: _____ 任务类型:_____ 提交搜索 WebGrid withPaging . 当我点击按钮搜索时,它会通过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",grid.Column(format: (item) => Html.ActionLink("Delete","Delete",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(),new { style = "width: 260px;" }) </td> </tr> <tr> <td> @Html.LabelFor(x => x.StatusId) </td> <td> @Html.DropDownListFor(x => x.StatusId,Model.GetStatusSelectList(),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") 所以,如果有人知道如何解决我的问题,我将不胜感激. 欢迎 解决方法
我认为这是因为每次单击下一页链接时都会替换网格.也许使用这样的东西:
@model IEnumerable<MVC3.Models.Task> @{ var grid = new WebGrid(null,autoSortAndPage: true); grid.Pager(mode: WebGridPagerModes.All); <div id="myGrid"> @grid.GetHtml( columns: grid.Columns( grid.Column(format: (item) => Html.ActionLink("Assign Notifications",format: (item) => item.Deadline.ToString("MM/dd/yyy")) ) ); </div> } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- asp.net – Chrome网络标签中的延迟测量
- asp.net – 使用冗长的服务器进程取消asynch回发
- asp.net-core-2.0 – ASP.NET MVC Core 2.0中多个记录的表数
- asp.net-mvc-3 – 从自定义授权属性访问角色
- 错误的请求 – 无效的主机名ASP.NET MVC4
- asp.net-core – 为什么需要在ASP.NET Core MVC中设置“Use
- 我应该使用用户名,还是用户ID来引用ASP.NET中的经过身份验证
- 将虚拟路径转换为ASP.NET中的实际Web路径
- asp.net-web-api – 将JSON数组从Javascript传递到Web API
- .net – 如何获取客户端DotNetOpenAuth.OAuth2返回的错误消
推荐文章
站长推荐
- asp.net-mvc – 依赖注入框架的重点是什么?
- asp.net-mvc-3 – 无法使用Enity Framework 4.0设
- asp.net-mvc-4 – 组合ASP.NET MVC4捆绑和requir
- asp.net – System.Web.UI.DataVisualization.Ch
- asp.net-mvc – MVC 2 vs MVC 3自定义验证属性使
- asp.net-mvc – ASP .Net MVC中购物车的会话变量
- asp.net – 在后面的代码中通过jquery添加列表框
- 如何从ASP.NET应用程序启动/停止Windows服务 –
- asp.net-mvc – 使JSON.NET和Serializable属性一
- asp.net-mvc – 如果在Razor MVC 3中浏览器未继承
热点阅读