查詢功能是開發中最重要的一個功能,大量數據的顯示,我們用的最多的就是分頁。
在ASP.NET 中有很多數據展現的控件,比如Repeater、GridView,用的最多的GridView,它同時也自帶了分頁的功能。但是我們知道用GridView來顯示數據,如果沒有禁用ViewState,頁面的大小會是非常的大的。而且平時我們點擊首頁,下一頁,上一頁,尾頁這些功能都是會引起頁面回發的,也就是需要完全跟服務器進行交互,來回響應的時間,傳輸的數據量都是很大的。
AJAX的分頁可以很好的解決這些問題。
數據顯示Pasing.aspx頁面JS代碼:
復制代碼 代碼如下:
<script type=text/javascript>
var pageIndex = 0;
var pageSize = 5;
window.onload = AjaxGetData(name,0,5);
function AjaxGetData(name, index, size){
$.ajax({
url: jQueryPaging.aspx,
type: Get,
data: Name= + name + &PageIndex= + index + &PageSize= + size,
dataType: json,
success: function (data) {
var htmlStr = ;
htmlStr +=
htmlStr +=
htmlStr +=
htmlStr += ;
htmlStr += //data.cloudfileLists.length
for (var i = 0; i < data.cloudfileLists.length; i++)
{
htmlStr += ;
htmlStr +=
+
htmlStr += ;
}
htmlStr += ;
htmlStr += ;
htmlStr += ;
htmlStr += ;
htmlStr += ;
htmlStr += ;
htmlStr += <table><thead><tr><td>編號</td><td>文件名</td></tr></thead><tbody><tr><td> + data.cloudfileLists[i].FileID + </td><td> + data.cloudfileLists[i].FileName + </td></tr></tbody><tfoot><tr><td colspan="'6'">;
htmlStr += <span>共有記錄 + data.Count + ;共<span id="'count'"> + (data.Count % 5 == 0 ? parseInt(data.Count / 5) : parseInt(data.Count / 5 + 1)) + </span>頁 + </span>;
htmlStr += 首 頁 ;
htmlStr += 前一頁 ;
htmlStr += 後一頁 ;
htmlStr += 尾 頁 ;
htmlStr += <input type="'text'"><input type="'button'" value="'跳轉'" onclick="'GoToAppointPage(this)'"> ;
htmlStr += </td></tr></tfoot></table>;
$(#divSearchResult).html(htmlStr);//重寫html
},
error: function (XMLHttpRequest, textStatus, errorThrown) {
alert(XMLHttpRequest);
alert(textStatus);
alert(errorThrown);
}
});
}
//首頁
function GoToFirstPage() {
pageIndex = 0;
AjaxGetData($(#txtSearch).val(), pageIndex, pageSize);
}
//前一頁
function GoToPrePage() {
pageIndex -= 1;
pageIndex = pageIndex >= 0 ? pageIndex : 0;
AjaxGetData($(#txtSearch).val(), pageIndex, pageSize);
}
//後一頁
function GoToNextPage() {
if (pageIndex + 1 < parseInt($(#count).text())) {
pageIndex += 1;
}
AjaxGetData($(#txtSearch).val(), pageIndex, pageSize);
}
//尾頁
function GoToEndPage() {
pageIndex = parseInt($(#count).text()) - 1;
AjaxGetData($(#txtSearch).val(), pageIndex, pageSize);
}
//跳轉
function GoToAppointPage(e) {
var page = $(e).prev().val();
if (isNaN(page)) {
alert(請輸入數字!);
}
else {
var tempPageIndex = pageIndex;
pageIndex = parseInt($(e).prev().val()) - 1;
if (pageIndex < 0 || pageIndex >= parseInt($(#count).text())) {
pageIndex = tempPageIndex;
alert(請輸入有效的頁面范圍!);
}
else {
AjaxGetData($(#txtSearch).val(), pageIndex, pageSize);
}
}
}
</script>
同一頁面HTML代碼:
jQueryPaging.aspx頁面的CS代碼如下:
引用這個命名空間:using System.Web.Script.Serialization;//JavaScriptSerializer要用的。
復制代碼 代碼如下:
protected void Page_Load(object sender, EventArgs e)
{
Int32 pageIndex = Int32.MinValue;
Int32 pageSize = Int32.MinValue;
String name = String.Empty;
JavaScriptSerializer jss = new JavaScriptSerializer();
if (Request[Name] != null)
{
name = Request[Name].ToString();
if (Request[PageIndex] != null)
{
pageIndex = Int32.Parse(Request[PageIndex].ToString());
pageSize = Request[PageSize] != null ? Int32.Parse(Request[PageSize].ToString()) : 5;
IList<cloudfile> cloudfileLists = new List<cloudfile>();//cloudfile是自己寫的類,表示一條數據</cloudfile></cloudfile>
CloudFile cf = null;
int cout = 0;
DataSet ds = LookDataFromDB(name, pageIndex, pageSize,out cout);
foreach (DataRow row in ds.Tables[0].Rows)//把你的數據重新封裝成Lis,才能被jss.Serialize(),不然會報錯。
{
cf = new CloudFile();
cf.FileID = row[FilePathId].ToString();
cf.FileName = row[FileName].ToString();
cloudfileLists.Add(cf);
}
if (cloudfileLists.Count > 0)
{
Response.Write({Count: + (cout) + ,cloudfileLists: + jss.Serialize(cloudfileLists) + });
Response.End();
}
}
}
}
private DataSet LookDataFromDB(string name, int pageIndex, int pageSize,out int cout)
{
DataSet ds = new DataSet();
try
{
pageIndex = 5 * pageIndex;//pageIndex ,表示這一頁從哪一條數據開始
// 這裡寫自己的數據獲取方法,把數據獲取好了甩到ds裡面,返回到前面。(應該有更好的辦法,自己想哦,也可以發評論我們一起探討....。)
}
catch (Exception)
{
cout = 0;
ds = null;
}
return ds;
}
復制代碼 代碼如下:
//<span style="font-family:">CloudFile類</span>
復制代碼 代碼如下:
public class CloudFile
{
public String FileID { get; set; }
public String FileName { get; set; }
public String FileDirName { get; set; }
}
這樣一個簡單的無刷新分頁的實例就完成了。由於本人的JS水平有限,現在只能做到這了。當然還可以添加一些新的功能。這裡我只是想將我的方法與大家分享。至於功能,待以後繼續完善了!!!