asp.net使用AJAX實現無重新整理分頁

來源:互聯網
上載者:User
查詢功能是開發中最重要的一個功能,大量資料的顯示,我們用的最多的就是分頁。

在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水平有限,現在只能做到這了。當然還可以添加一些新的功能。這裡我只是想將我的方法與大家分享。至於功能,待以後繼續完善了!!!

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.