MVC中,查询以异步呈现,分页不用异步的解决方案

Posted 那就让我这样吧

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MVC中,查询以异步呈现,分页不用异步的解决方案相关的知识,希望对你有一定的参考价值。

MVC中,查询以异步呈现,分页不用异步的解决方案

这种需求,用一个ASPX页面和一个ASCX分部视图就可以解决了,ASPX提供对ASCX的引用,ASCX显示列表信息,ASPX主页面提供查询功能

<% using (html.BeginForm())
{%>
<%Html.RenderAction("AllPropertyForSelectList", "Common"); %><input type="button"
value="查询" class="button" id="search" />
<div id="list">
<%Html.RenderPartial("Common_BasePropValueList",Model); %>
</div>
<%} %>

查询功能的JS

<script type="text/javascript">
$(function () {
$("#search").click(function () {
$.ajax({
type: "POST",
url: "/Common_BaseProp/Index",
data: { page: "<%=Model.PageIndex %>", pid: $("#PID").val() },
success: function (data) {
$("#list").html(data);
}
})
});
});
</script>


controller代码:

public ActionResult Index(int? page, int? pid)
{
vp = new Entity.VPredication();
pp = new Entity.PagingParam(page ?? 1, PAGESIZE);
if (pid != null)
vp.AddItem("pid", pid);
Entity.PagedList<Common_BasePropValue_Ext> model = iCommon_BasePropValueService.GetAllBasePropValue(vp, pp);
if (Request.IsAjaxRequest()) //通过判断请求,来确定是返回页面,还是返回分部视图
return PartialView("Common_BasePropValueList",model);
else
return View(model);
}

以上是关于MVC中,查询以异步呈现,分页不用异步的解决方案的主要内容,如果未能解决你的问题,请参考以下文章

ASP.NET MVC中使用MvcPager异步分页+在分页中复选框下一页上一页也保持选中

mvc中的异步页面加载

MVC分页之MvcPager使用

大数据量的报表如何快速分页呈现,有什么好的处理方法

原创10万条数据采用存储过程分页实现(Mvc+Dapper+存储过程)

mysql优化---订单查询优化:异步分页处理