
实现原理很简单,使用了JQuery.pagination这个插件,每当点击页码时异步去服务器去取该页的数据,简单介绍如下:
一、数据库表结构:很简单 就四个字段 分别是News_id News_title News_time News_readtimes
二、前台页面代码:
<head runat="server">
<title>jQuery无刷新分页</title>
<link href="Styles/common.CSS" rel="StyleSheet" type="text/css" />
<link href="Styles/paging.css" rel="stylesheet" type="text/css" />
<script src="Scripts/jquery-1.4.1.JS" type="text/javascript"></script>
<script src="Scripts/jquery.pagination.js" type="text/JavaScript"></script>
<script type="text/Javascript">
var pageIndex = 0;
var pageSize = 3;
$(function() {
Inittable(0);
$("#Pagination").pagination(<%=pageCount %>, {
callback: PageCallback,
PRev_text: '上一页',
next_text: '下一页',
items_per_page: pageSize,
num_display_entries: 6,//连续分页主体部分分页条目数
current_page: pageIndex,//当前页索引
num_Edge_entrIEs: 2//两侧首尾分页条目数
});
//翻页调用
function PageCallback(index, JQ) {
Inittable(index);
}
//请求数据
function InitTABle(pageIndex) {
$.Ajax({
type: "post",
dataType: "text",
url: 'ajax/PagerHandler.ashx',
data: "pageIndex=" + (pageIndex + 1) + "&pageSize=" + pageSize,
success: function(data) {
$("#Result tr:gt(0)").remove();//移除Id为Result的表格里的行,从第二行开始(这里根据页面布局不同页变)
$("#Result").append(data);//将返回的数据追加到表格
}
});
}
});
</script>
</head>
<FORM id="form1" runat="server">
<center>
<table id="Result" border="1" cellpadding="5" style="border-collapse: collapse; margin:20px;
border: solid 1px #85A8BE;width:60%">
<tr>
<th style="width: 10%">
ID
</th>
<th style="width: 60%">
标题
</th>
<th style="width: 20%">
更新时间
</th>
<th style="width: 10%">
点击量
</th>
</tr>
</table>
<div id="Pagination" class="paging">
</div>
</center>
</Form>
三、页面后台文件
这里主要是获取记录总数:
public string pageCount = String.Empty;//总条目数
protected void Page_load(Object sender, eventArgs e)
{
if (!IsPostBack)
{
pageCount = new News().getNewsCount();
}
}
四、最主要的是ajax处理程序:PagerHandler.ashx
public class PagerHandler : IhttpHandler
{
public void ProcessRequest(HTTPContext context)
{
context.Response.ContentType = "text/plAIn";
string str = string.Empty;
int pageIndex = Convert.ToInt32(context.Request["pageIndex"]);
int size = Convert.ToInt32(context.Request["pageSize"]);
if (pageIndex == 0)
{
pageIndex = 1;
}
int count = 0;
News n = new News();
list<News> list = n.GetNewsList(pageIndex, size, ref count);
StringBUIlder sb = new StringBuilder();
forEach (News p in list)
{
sb.APPend("<tr><td>");
sb.append(p.News_id);
sb.Append("</td><td>");
sb.Append("<a href='#'>"+p.News_title+"</a>");
sb.Append("</td><td>");
sb.Append(p.News_time);
sb.Append("</td><td>");
sb.Append(p.News_readtimes);
sb.Append("</td></tr>");
}
str = sb.toString();
context.Response.Write(str);
}








网友评论文明上网理性发言已有0人参与
发表评论: