AJAX 分页 asp.net分页

原文链接:http://www.cnblogs.com/chenping-987123/archive/2011/02/14/1954640.html


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

在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)<span style="font-family: Arial, Helvetica, sans-serif;"> {</span>
            $.ajax({
                url: "jQueryPaging.aspx",
                type: "Get",
                data: "Name=" + name + "&PageIndex=" + index + "&PageSize=" + size,
                dataType: "json",
                success: function (data) {
                    var htmlStr = "";
                    htmlStr += "<table>"
                    htmlStr += "<thead>"
                    htmlStr += "<tr><td>编号</td><td>文件名</td></tr>"
                    htmlStr += "</thead>";
                    htmlStr += "<tbody>"   //data.cloudfileLists.length
                    for (var i = 0; i < data.cloudfileLists.length; i++) 
                    {
                        htmlStr += "<tr>";
                        htmlStr += "<td>" + data.cloudfileLists[i].FileID + "</td>"
                                          + "<td>" + data.cloudfileLists[i].FileName + "</td>"
                        htmlStr += "</tr>";
                    }
                    htmlStr += "</tbody>";
                    htmlStr += "<tfoot>";
                    htmlStr += "<tr>";
                    htmlStr += "<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 += "<a href='javascript:void' οnclick='GoToFirstPage()' id='aFirstPage' >首    页</a>   ";
                    htmlStr += "<a href='javascript:void' οnclick='GoToPrePage()' id='aPrePage' >前一页</a>   ";
                    htmlStr += "<a href='javascript:void' οnclick='GoToNextPage()' id='aNextPage'>后一页</a>   ";
                    htmlStr += "<a href='javascript:void' οnclick='GoToEndPage()' id='aEndPage' >尾    页</a>   ";
                    htmlStr += "<input type='text' /><input type='button'  value='跳转' οnclick='GoToAppointPage(this)' /> ";
                    htmlStr += "</td>";
                    htmlStr += "</tr>";
                    htmlStr += "</tfoot>";
                    htmlStr += "</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代码:


<body>
    <form id="form1" runat="server">
    <div>
    </div>
         <div id="divSearchResult">
    </div>
    </form>
</body>
jQueryPaging.aspx页面的CS代码如下:
引用这个命名空间:using System.Web.Script.Serialization;//JavaScriptSerializer要用的。
protected void Page_Load(object sender, EventArgs e)</span>
        {


            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 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: Arial, Helvetica, sans-serif;">CloudFile类</span>
    public class CloudFile
    {
        public String FileID { get; set; }
        public String FileName { get; set; }
        public String FileDirName { get; set; }
    }
本文方法来源于:http://www.cnblogs.com/chenping-987123/archive/2011/02/14/1954640.html
基本思路都是上面链接提供的,感谢上文作者。
有问题可以继续探讨,我基本还是看懂了的.....

Asp+AJAX静态分页 亲测 可用 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> <title>Asp+AJAX静态分页</title> <style type="text/css"> <!-- body { text-align:center;font:14px Verdana,sans-serif; } a:link,a:visited { color:#00f;text-decoration:none; } a:hover { color:#f00;text-decoration:underline; } #main { width:450px;background:#f2f2f2;border:1px #999 solid;padding:10px;text-align:left;line-height:150%;margin:0 auto; } #title { width:100%;line-height:30px;border-bottom:1px #999 solid;display:table; } #left { float:left;width:50%;text-align:left;font-size:14px;font-weight:bold; } #right { float:left;width:50%;text-align:right; } #content { width:100%;margin:10px 0;clear:both; } #download { width:100%;margin:10px 0;line-height:150%; } --> </style> [removed] <!-- function createAjax() { //该函数将返回XMLHTTP对象实例 var _xmlhttp; try { _xmlhttp=new ActiveXObject("Microsoft.XMLHTTP"); //IE的创建方式 } catch (e) { try { _xmlhttp=new XMLHttpRequest(); //FF等浏览器的创建方式 } catch (e) { _xmlhttp=false; //如果创建失败,将返回false } } return _xmlhttp; //返回xmlhttp对象实例 } function getweblist(page) { //该函数用来获取分页数据 var xmlhttp=createAjax(); //创建变量xmlhttp,并将createAjax()函数创建的对象实例赋于它 if (xmlhttp) { //如果xmlhttp对象创建成功,则执行条件语句中的程序 var content=document.getElementById('content'); //获取页面中id为content的对象 xmlhttp.open('get','server.asp?page='+page+'&n='+Math.random(),true); //打开与服务器的连接,其中get为连接方式,server.asp为要连接的页面,有两个参数,其中第一个参数page为需要返回数据的页数,第二个参数n为一个随机数,这样每次发送的URL都会不一样,相当于都向服务器发出一个新的请求,避免浏览器缓存数据。 xmlhttp.onreadystatechange=function() { //为xmlhttp对象的readyState属性指定事件,改属性值改变时,则会执行其中的程序 if (xmlhttp.readyState==4 && xmlhttp.status==200) { //如果xmlhttp.readyState==4并且xmlhttp.status==200时,执行条件中的程序,其中readyState有五个值,4为请求完成,是客户端向服务器提交的数据成功到达,status有N多值-_-!!,其中200为OK,是指服务器向客户端完成发送数据。 content[removed]=unescape(xmlhttp.responseText); //将服务器返回的数据解码并写入指定的ID中。 } else { content[removed]='<span>正在从服务器提取数据......</span>'; //如果服务器没有完成传送,则向用户提示正在传输。 } } xmlhttp.send(null); //向服务器发送请求,因为是get请求,会直接附在URL后面,所以这里括号中的数据为null,IE中也可以不写,但FF就必须加上null,否则会发送失败。 } } function edit() { //编辑分页显示条数的函数 var str='<form style="margin:0">每页显示 <input type="text" id="pagesize" size="3"> 条 <input type="button" id="savebtn" value="保存" onclick="save()"> <input type="button" id="cancelbtn" value="取消" onclick="rightinfo()"></form>' //定义html字符串 var right=document.getElementById('right'); //获得页面中的right对象。 right[removed]=str; //将str变量的值写入该对象中。 } function rightinfo() { //right对象中的原始信息,请在页面开始和被显示条数被修改后调用 document.getElementById('right')[removed]='<a href="[removed]void(edit())" title="修改每页显示条数">Edit</a>'; } function save() { //保存修改后的显示条数 var pagesize=document.getElementById('pagesize'); //这个就不写了,跟上面的用法一样。 if (pagesize.value==''||/[0-9]+/.test(pagesize.value)==false) { //确定用户输入的新数据是不是一个数字 alert("请正确填写每页显示条数! "); return; } var xmlhttp=createAjax(); //创建对象 if (xmlhttp) { xmlhttp.open('get','set.asp?pagesize='+pagesize.value+'&n='+Math.random(),true) //参上同看 xmlhttp.onreadystatechange=function() { if (xmlhttp.readyState==4 && xmlhttp.status==200) { document.getElementById('right')[removed]=unescape(xmlhttp.responseText); //先写入从服务器返回的字符串,如果成功,会写入completed。 getweblist(1); //从新获取新修改后的第一页的数据 setTimeout('rightinfo()',3000); //3秒后将right对象的原始字符串写入。 } else { document.getElementById('pagesize').disabled=true; //将几个FORM表单的元素都设为不可改动 document.getElementById('savebtn').disabled=true; document.getElementById('cancelbtn').disabled=true; } } xmlhttp.send(null); //发送请求。 } } //--> [removed] </head> <body> <div id="main"> <div id="title"> <div id="left">Asp+AJAX静态分页</div> <div id="right"></div> </div> <div id="content"></div> </div> </body> </html>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值