Jquery Ajax.ashx 高效分页实现代码高效分页实现代码
以前的我,用惯了 UpdatePanel UpdateProgress 等控件,甚至到了滥用的程度,只是一味的追求无刷新,一边弄这 loading 图
片 提示,这样貌似更美观,但是 感觉 更损失了性能, 而且有时候还破坏了网站的完整性。
但是学了Jquery之后,了解了 Jquery.ajax ,Jquery.get 等方法,从而学会了使用 webservice 和.ashx 文件,来与服务器交互。
这次的Jquery分页 是与 .ashx文件配合的。
建立三个.ashx,分别为PreviewHandler.ashx,PageHandler.ashx,NextHandler.ashx,分别来处理当前页,下一页,上一页的处
理。
PageHandler.ashx
代码如下:
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = “text/plain”;
IQueryable<Answer> answer = xt.Answer.Take(10);
StringBuilder sb = new StringBuilder();
sb.Append(“<table border=’1′ width=’900px;’><tr><th>回答内容</th><th>回答用户名</th><th>创建时间</th></tr>”);
foreach (Answer a in answer)
{
sb.Append(“<tr><td>” + a.Answer_content + “</td><td>” + a.Answer_UserName + “</td><td
onclick=’javascript:alert(“+”aa”+”)’>” + a.Answer_Creatime + “</td></tr>”);
}
sb.Append(“</table>”);
context.Response.Write(sb);
}
NextHandler.ashx
代码如下:
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = “text/plain”;
int RowCount = 10;
int Current = Convert.ToInt32(context.Request.Params[“index”]) + 1;
IQueryable<Answer> answer = xt.Answer.Skip(RowCount * (Current – 1)).Take(RowCount);
StringBuilder sb = new StringBuilder();
sb.Append(“<table border=’1′ width=’900px;’><tr><th>回答内容</th><th>回答用户名</th><th>创建时间</th></tr>”);
foreach (Answer a in answer)
{
sb.Append(“<tr><td>” + a.Answer_content + “</td><td>” + a.Answer_UserName + “</td><td>” + a.Answer_Creatime + “</td>
</tr>”);
}
sb.Append(“</table>”);
context.Response.Write(sb);
}
PreviewHandler.ashx
代码如下:
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = “text/plain”;
int RowCount = 10;
int Current = Convert.ToInt32(context.Request.Params[“index”]) – 1;
IQueryable<Answer> answer = xt.Answer.Skip(RowCount * (Current – 1)).Take(RowCount);
StringBuilder sb = new StringBuilder();
sb.Append(“<table border=’1′ width=’900px;’><tr><th>回答内容</th><th>回答用户名</th><th>创建时间</th></tr>”);
foreach (Answer a in answer)
{
sb.Append(“<tr><td>” + a.Answer_content + “</td><td>” + a.Answer_UserName + “</td><td>” + a.Answer_Creatime + “</td>
</tr>”);
}
sb.Append(“</table>”);
context.Response.Write(sb);
}
三个文件其实代码大多类似,然后通过html或者aspx文件来调用,用Jquery.get()
代码如下:
<div id=”lab”>
<input type=”button” onclick=”Init();” value=”初始化数据” />
<div id=”content” style=”width:100%”>
</div>