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 += 
编号文件名
+ data.cloudfileLists[i].FileID + + data.cloudfileLists[i].FileName +
; htmlStr += 共有记录 + data.Count + ;共 + (data.Count % 5 == 0 ? parseInt(data.Count / 5) : parseInt(data.Count / 5 + 1)) + 页 + ; htmlStr += 首 页 ; htmlStr += 前一页 ; htmlStr += 后一页 ; htmlStr += 尾 页 ; htmlStr += ; htmlStr += ; $(#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 = 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水平有限,现在只能做到这了。当然还可以添加一些新的功能。这里我只是想将我的方法与大家分享。至于功能,待以后继续完善了!!!

更多asp.net使用AJAX实现无刷新分页相关文章请关注PHP中文网!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2552958.html

(0)
上一篇 2025年3月6日 06:37:17
下一篇 2025年3月6日 06:37:22

AD推荐 黄金广告位招租... 更多推荐

发表回复

登录后才能评论