当前位置: 移动技术网 > IT编程>开发语言>.net > AJAX 分页 asp.net分页

AJAX 分页 asp.net分页

2018年02月08日  | 移动技术网IT编程  | 我要评论

新恋爱时代小说下载,长沙建网站,acfun打不开

 


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

在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 ;
                        htmlStr +=  + data.cloudfileLists[i].FileID + 
                                          +  + data.cloudfileLists[i].FileName + 
                        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 += ;
                    htmlStr += ;
                    htmlStr += ;
                    htmlStr += ;

                    $(#pSearchResult).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 = 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 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; }
    }

本文方法来源于:https://www.cnblogs.com/chenping-987123/archive/2011/02/14/1954640.html
基本思路都是上面链接提供的,感谢上文作者。
有问题可以继续探讨,我基本还是看懂了的.....
再次致谢.....





 

 

 

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网