Jquery+Ajax+Json을 기반으로 한 효율적인 페이징 구현 코드

高洛峰
풀어 주다: 2017-01-12 10:09:15
원래의
876명이 탐색했습니다.

텍스트
먼저 데이터베이스의 내용을 읽고 반환 값을 가져오는 일반 핸들러를 만듭니다.
GetData.ashx라는 파일을 만듭니다.
여기에서는 저장 프로시저를 사용합니다. 저장 프로시저는 아래에 붙여넣습니다. 데이터는 단지 예시일 뿐이며 필요에 따라 직접 읽어도 됩니다.

<%@ WebHandler Language="C#" Class="GetData" %> 
using System; 
using System.Web; 
using System.Data.SqlClient; 
using System.Data; 
using System.Collections.Generic; 
using System.Web.Script.Serialization; 
public class GetData : IHttpHandler { 
public void ProcessRequest (HttpContext context) { 
context.Response.ContentType = "text/plain"; 
var pageIndex = context.Request["PageIndex"]; 
string connectionString = @"Data Source=KUSE\SQLEXPRESS;Initial Catalog=bookshop;Integrated Security=True"; 
//判断当前索引存不存在,如果不存在则获取记录的总数。 
if (string.IsNullOrEmpty(pageIndex)) 
{ 
//获取查询记录总数的sql语句 
string sql = "select count(-1) from books"; 
int count = 0; 
int.TryParse(SqlHelper.ExecuteScalar(connectionString, System.Data.CommandType.Text, sql, null).ToString(), out count); 
context.Response.Write(count); 
context.Response.End(); 
} 
//当根据索引获取数据 
else 
{ 
int currentPageIndex = 1; 
int.TryParse(pageIndex, out currentPageIndex); 
SqlParameter[] parms = new SqlParameter[] { 
new SqlParameter("@FEILDS",SqlDbType.NVarChar,1000), 
new SqlParameter("@PAGE_INDEX",SqlDbType.Int,10), 
new SqlParameter("@PAGE_SIZE",SqlDbType.Int,10), 
new SqlParameter("@ORDERTYPE",SqlDbType.Int,2), 
new SqlParameter("@ANDWHERE",SqlDbType.VarChar,1000), 
new SqlParameter("@ORDERFEILD",SqlDbType.VarChar,100) 
}; 
parms[0].Value = "*";//获取所有的字段 
parms[1].Value = pageIndex;//当前页面索引 
parms[2].Value = 10;//页面大小 
parms[3].Value = 0;//升序排列 
parms[4].Value = "";//条件语句 
parms[5].Value = "ID";//排序字段 
List<Book> list = new List<Book>(); 
using (SqlDataReader sdr = SqlHelper.ExecuteReader(connectionString, CommandType.StoredProcedure, "PAGINATION", parms)) 
{ 
while (sdr.Read()) 
{ 
list.Add(new Book { Title = sdr[2].ToString(), Auhor = sdr[2].ToString(), PublishDate = sdr[4].ToString(), ISBN = sdr[5].ToString() }); 
} 
} 
context.Response.Write(new JavaScriptSerializer().Serialize(list).ToString());//转为Json格式 
} 
} 
public bool IsReusable { 
get { 
return false; 
} 
} 
} 
public class Book 
{ 
public string Title { get; set; } 
public string Auhor { get; set; } 
public string PublishDate { get; set; } 
public string ISBN { get; set; } 
}
로그인 후 복사
표시 데이터 페이지----jquery를 기반으로 생성된 데이터를 얻기 위한 비동기 요청

Page Show.htm

<body> 
<div > 
<table id="content">/*显示数据内容*/ 
</table> 
<div id="pager" class="yahoo2"></div>/*显示分页条*/ 
</div> 
</body>
로그인 후 복사
js 코드

$(function () { 
$.post("GetData.ashx", null, function (data) { 
var total = data; 
PageClick(1, total, 3); 
}); 
PageClick = function (pageIndex, total, spanInterval) { 
$.ajax({ 
url: "GetData.ashx", 
data: { "PageIndex": pageIndex }, 
type: "post", 
dataType: "json", 
success: function (data) { 
//索引从1开始 
//将当前页索引转为int类型 
var intPageIndex = parseInt(pageIndex); 
//获取显示数据的表格 
var table = $("#content"); 
//清楚表格中内容 
$("#content tr").remove(); 
//向表格中添加内容 
for (var i = 0; i < data.length; i++) { 
table.append( 
$("<tr><td>" + 
data[i].Title 
+ "</td><td>" + 
data[i].Auhor 
+ "</td><td>" + 
data[i].PublishDate 
+ "</td><td>" + 
data[i].ISBN 
+ "</td></tr>") 
); 
} //for 
//创建分页 
//将总记录数结果 得到 总页码数 
var pageS = total 
if (pageS % 10 == 0) pageS = pageS / 10; 
else pageS = parseInt(total / 10) + 1; 
var $pager = $("#pager"); 
//清楚分页div中的内容 
$("#pager span").remove(); 
$("#pager a").remove(); 
//添加第一页 
if (intPageIndex == 1) 
$pager.append("<span class=&#39;disabled&#39;>第一页</span>"); 
else { 
var first = $("<a href=&#39;javascript:void(0)&#39; first=&#39;" + 1 + "&#39;>第一页</a>").click(function () { 
PageClick($(this).attr(&#39;first&#39;), total, spanInterval); 
return false; 
}); 
$pager.append(first); 
} 
//添加上一页 
if (intPageIndex == 1) 
$pager.append("<span class=&#39;disabled&#39;>上一页</span>"); 
else { 
var pre = $("<a href=&#39;javascript:void(0)&#39; pre=&#39;" + (intPageIndex - 1) + "&#39;>上一页</a>").click(function () { 
PageClick($(this).attr(&#39;pre&#39;), total, spanInterval); 
return false; 
}); 
$pager.append(pre); 
} 
//设置分页的格式 这里可以根据需求完成自己想要的结果 
var interval = parseInt(spanInterval); //设置间隔 
var start = Math.max(1, intPageIndex - interval); //设置起始页 
var end = Math.min(intPageIndex + interval, pageS)//设置末页 
if (intPageIndex < interval + 1) { 
end = (2 * interval + 1) > pageS ? pageS : (2 * interval + 1); 
} 
if ((intPageIndex + interval) > pageS) { 
start = (pageS - 2 * interval) < 1 ? 1 : (pageS - 2 * interval); 
} 
//生成页码 
for (var j = start; j < end + 1; j++) { 
if (j == intPageIndex) { 
var spanSelectd = $("<span class=&#39;current&#39;>" + j + "</span>"); 
$pager.append(spanSelectd); 
} //if 
else { 
var a = $("<a href=&#39;javascript:void(0)&#39;>" + j + "</a>").click(function () { 
PageClick($(this).text(), total, spanInterval); 
return false; 
}); 
$pager.append(a); 
} //else 
} //for 
//上一页 
if (intPageIndex == total) { 
$pager.append("<span class=&#39;disabled&#39;>下一页</span>"); 
} 
else { 
var next = $("<a href=&#39;javascript:void(0)&#39; next=&#39;" + (intPageIndex + 1) + "&#39;>下一页</a>").click(function () { 
PageClick($(this).attr("next"), total, spanInterval); 
return false; 
}); 
$pager.append(next); 
} 
//最后一页 
if (intPageIndex == pageS) { 
$pager.append("<span class=&#39;disabled&#39;>最后一页</span>"); 
} 
else { 
var last = $("<a href=&#39;javascript:void(0)&#39; last=&#39;" + pageS + "&#39;>最后一页</a>").click(function () { 
PageClick($(this).attr("last"), total, spanInterval); 
return false; 
}); 
$pager.append(last); 
} 
} //sucess 
}); //ajax 
}; //function 
}); //ready
로그인 후 복사
페이징 스타일----If 관심이 있으신가요? 여기에 20개 이상의 페이징 스타일 세트가 있습니다.

<style type="text/css"> 
DIV.yahoo2 { 
PADDING-RIGHT: 3px; PADDING-LEFT: 3px; FONT-SIZE: 0.85em; PADDING-BOTTOM: 3px; MARGIN: 3px; PADDING-TOP: 3px; FONT-FAMILY: Tahoma,Helvetica,sans-serif; TEXT-ALIGN: center 
} 
DIV.yahoo2 A { 
BORDER-RIGHT: #ccdbe4 1px solid; PADDING-RIGHT: 8px; BACKGROUND-POSITION: 50% bottom; BORDER-TOP: #ccdbe4 1px solid; PADDING-LEFT: 8px; PADDING-BOTTOM: 2px; BORDER-LEFT: #ccdbe4 1px solid; COLOR: #0061de; MARGIN-RIGHT: 3px; PADDING-TOP: 2px; BORDER-BOTTOM: #ccdbe4 1px solid; TEXT-DECORATION: none 
} 
DIV.yahoo2 A:hover { 
BORDER-RIGHT: #2b55af 1px solid; BORDER-TOP: #2b55af 1px solid; BACKGROUND-IMAGE: none; BORDER-LEFT: #2b55af 1px solid; COLOR: #fff; BORDER-BOTTOM: #2b55af 1px solid; BACKGROUND-COLOR: #3666d4 
} 
DIV.yahoo2 A:active { 
BORDER-RIGHT: #2b55af 1px solid; BORDER-TOP: #2b55af 1px solid; BACKGROUND-IMAGE: none; BORDER-LEFT: #2b55af 1px solid; COLOR: #fff; BORDER-BOTTOM: #2b55af 1px solid; BACKGROUND-COLOR: #3666d4 
} 
DIV.yahoo2 SPAN.current { 
PADDING-RIGHT: 6px; PADDING-LEFT: 6px; FONT-WEIGHT: bold; PADDING-BOTTOM: 2px; COLOR: #000; MARGIN-RIGHT: 3px; PADDING-TOP: 2px 
} 
DIV.yahoo2 SPAN.disabled { 
DISPLAY: none 
} 
DIV.yahoo2 A.next { 
BORDER-RIGHT: #ccdbe4 2px solid; BORDER-TOP: #ccdbe4 2px solid; MARGIN: 0px 0px 0px 10px; BORDER-LEFT: #ccdbe4 2px solid; BORDER-BOTTOM: #ccdbe4 2px solid 
} 
DIV.yahoo2 A.next:hover { 
BORDER-RIGHT: #2b55af 2px solid; BORDER-TOP: #2b55af 2px solid; BORDER-LEFT: #2b55af 2px solid; BORDER-BOTTOM: #2b55af 2px solid 
} 
DIV.yahoo2 A.prev { 
BORDER-RIGHT: #ccdbe4 2px solid; BORDER-TOP: #ccdbe4 2px solid; MARGIN: 0px 10px 0px 0px; BORDER-LEFT: #ccdbe4 2px solid; BORDER-BOTTOM: #ccdbe4 2px solid 
} 
DIV.yahoo2 A.prev:hover { 
BORDER-RIGHT: #2b55af 2px solid; BORDER-TOP: #2b55af 2px solid; BORDER-LEFT: #2b55af 2px solid; BORDER-BOTTOM: #2b55af 2px solid 
} 
</style>
로그인 후 복사
페이징 저장 프로시저---PAGINATION

CREATE PROCEDURE [dbo].[PAGINATION] 
@FEILDS VARCHAR(1000),--要显示的字段 
@PAGE_INDEX INT,--当前页码 
@PAGE_SIZE INT,--页面大小 
@ORDERTYPE BIT,--当为0时 则为 desc 当为1 时 asc 
@ANDWHERE VARCHAR(1000)=&#39;&#39;,--where语句 不用加where 
@ORDERFEILD VARCHAR(100) --排序的字段 
as 
DECLARE @EXECSQL VARCHAR(2000) 
DECLARE @ORDERSTR VARCHAR(100) 
DECLARE @ORDERBY VARCHAR(100) 
BEGIN 
set NOCOUNT on 
IF @ORDERTYPE = 1 
BEGIN 
SET @ORDERSTR = &#39; > ( SELECT MAX([&#39;+@ORDERFEILD+&#39;])&#39; 
SET @ORDERBY = &#39;ORDER BY &#39;+@ORDERFEILD+&#39; ASC&#39; 
END 
ELSE 
BEGIN 
SET @ORDERSTR = &#39; < ( SELECT MIN([&#39;+@ORDERFEILD+&#39;])&#39; 
SET @ORDERBY = &#39;ORDER BY &#39;+@ORDERFEILD+&#39; DESC&#39; 
END 
IF @PAGE_INDEX = 1 --当页码是第一页时直接运行,提高速度 
BEGIN 
IF @ANDWHERE=&#39;&#39; 
SET @EXECSQL = &#39;SELECT TOP &#39;+STR(@PAGE_SIZE)+&#39; &#39;+@FEILDS+&#39; FROM [books] &#39;+@ORDERBY 
ELSE 
SET @EXECSQL = &#39;SELECT TOP &#39;+STR(@PAGE_SIZE)+&#39; &#39;+@FEILDS+&#39; FROM [books] WHERE &#39;+@ANDWHERE+&#39; &#39;+ @ORDERBY 
END 
ELSE 
BEGIN 
IF @ANDWHERE=&#39;&#39; 
BEGIN --以子查询结果当做新表时 要给表名别名才能用 
SET @EXECSQL = &#39;SELECT TOP&#39;+STR(@PAGE_SIZE)+&#39; &#39;+@FEILDS+&#39; FROM [books] WHERE &#39;+@ORDERFEILD+ 
@ORDERSTR+&#39; FROM (SELECT TOP &#39;+STR(@PAGE_SIZE*(@PAGE_INDEX-1))+&#39; &#39;+@ORDERFEILD+ 
&#39; FROM [books] &#39;+@ORDERBY+&#39;) AS TEMP) &#39;+ @ORDERBY 
END 
ELSE 
BEGIN 
SET @EXECSQL = &#39;SELECT TOP&#39;+STR(@PAGE_SIZE)+&#39; &#39;+@FEILDS+&#39; FROM [books] WHERE &#39;+@ORDERFEILD+ 
@ORDERSTR+&#39; FROM (SELECT TOP &#39;+ STR(@PAGE_SIZE*(@PAGE_INDEX-1))+&#39; &#39;+@ORDERFEILD+ 
&#39; FROM [books] WHERE &#39;+@ANDWHERE+&#39; &#39;+@ORDERBY+&#39;) AS TEMP) AND &#39;+@ANDWHERE+&#39; &#39;+ @ORDERBY 
END 
END 
EXEC (@EXECSQL)--这里要加括号 
END
로그인 후 복사
PageClick(1, total, 3); , 첫 번째 매개변수는 현재 페이지 번호이고, 첫 번째 호출은 첫 번째 페이지이므로 필요하지 않습니다. Tube, total: 총 레코드 수를 나타내고, 세 번째 매개변수는 다음을 나타냅니다. 현재 색인과 다음 색인 사이의 페이지 수 one

Jquery+Ajax+Json 기반의 효율적인 페이징 구현 코드에 대한 더 많은 글은 PHP 중국어 홈페이지를 주목해주세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿