ajax.net 无刷新分页,asp.net使用AJAX实现无刷新分页

查询功能是开发中最重要的一个功能,大量数据的显示,我们用的最多的就是分页。

在ASP.NET 中有很多数据展现的控件,比如Repeater、GridView,用的最多的GridView,它同时也自带了分页的功能。但是我们知道用GridView来显示数据,如果没有禁用ViewState,页面的大小会是非常的大的。而且平时我们点击首页,下一页,上一页,尾页这些功能都是会引起页面回发的,也就是需要完全跟服务器进行交互,来回响应的时间,传输的数据量都是很大的。

AJAX的分页可以很好的解决这些问题。

数据显示Pasing.aspx页面JS代码:

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 +=

编号文件名
;

htmlStr += 共有记录 + data.Count + ;共 + (data.Count % 5 == 0 ? parseInt(data.Count / 5) : parseInt(data.Count / 5 + 1)) + 页 + ;

htmlStr += 首    页   ;

htmlStr += 前一页   ;

htmlStr += 后一页   ;

htmlStr += 尾    页   ;

htmlStr += ;

htmlStr +=

+ data.cloudfileLists[i].FileID + + data.cloudfileLists[i].FileName +
;

$(#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);

}

}

}

同一页面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 cloudfileLists = new List();//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;

}

//CloudFile类

public class CloudFile

{

public String FileID { get; set; }

public String FileName { get; set; }

public String FileDirName { get; set; }

}

这样一个简单的无刷新分页的实例就完成了。由于本人的JS水平有限,现在只能做到这了。当然还可以添加一些新的功能。这里我只是想将我的方法与大家分享。至于功能,待以后继续完善了!!!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值