asp.net使用AJAX實(shí)現(xiàn)無(wú)刷新分頁(yè)

字號(hào):


    查詢功能是開(kāi)發(fā)中最重要的一個(gè)功能,大量數(shù)據(jù)的顯示,我們用的最多的就是分頁(yè)。
    在ASP.NET 中有很多數(shù)據(jù)展現(xiàn)的控件,比如Repeater、GridView,用的最多的GridView,它同時(shí)也自帶了分頁(yè)的功能。但是我們知道用GridView來(lái)顯示數(shù)據(jù),如果沒(méi)有禁用ViewState,頁(yè)面的大小會(huì)是非常的大的。而且平時(shí)我們點(diǎn)擊首頁(yè),下一頁(yè),上一頁(yè),尾頁(yè)這些功能都是會(huì)引起頁(yè)面回發(fā)的,也就是需要完全跟服務(wù)器進(jìn)行交互,來(lái)回響應(yīng)的時(shí)間,傳輸?shù)臄?shù)據(jù)量都是很大的。
    AJAX的分頁(yè)可以很好的解決這些問(wèn)題。
    數(shù)據(jù)顯示Pasing.aspx頁(yè)面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>編號(hào)</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>頁(yè) + </span>;
    htmlStr += 首 頁(yè) ;
    htmlStr += 前一頁(yè) ;
    htmlStr += 后一頁(yè) ;
    htmlStr += 尾 頁(yè) ;
    htmlStr += <input type="'text'"><input type="'button'" value="'跳轉(zhuǎn)'" onclick="'GoToAppointPage(this)'"> ;
    htmlStr += </td></tr></tfoot></table>;
    $(#divSearchResult).html(htmlStr);//重寫html
    },
    error: function (XMLHttpRequest, textStatus, errorThrown) {
    alert(XMLHttpRequest);
    alert(textStatus);
    alert(errorThrown);
    }
    });
    }
    //首頁(yè)
    function GoToFirstPage() {
    pageIndex = 0;
    AjaxGetData($(#txtSearch).val(), pageIndex, pageSize);
    }
    //前一頁(yè)
    function GoToPrePage() {
    pageIndex -= 1;
    pageIndex = pageIndex >= 0 ? pageIndex : 0;
    AjaxGetData($(#txtSearch).val(), pageIndex, pageSize);
    }
    //后一頁(yè)
    function GoToNextPage() {
    if (pageIndex + 1 < parseInt($(#count).text())) {
    pageIndex += 1;
    }
    AjaxGetData($(#txtSearch).val(), pageIndex, pageSize);
    }
    //尾頁(yè)
    function GoToEndPage() {
    pageIndex = parseInt($(#count).text()) - 1;
    AjaxGetData($(#txtSearch).val(), pageIndex, pageSize);
    }
    //跳轉(zhuǎn)
    function GoToAppointPage(e) {
    var page = $(e).prev().val();
    if (isNaN(page)) {
    alert(請(qǐng)輸入數(shù)字!);
    }
    else {
    var tempPageIndex = pageIndex;
    pageIndex = parseInt($(e).prev().val()) - 1;
    if (pageIndex < 0 || pageIndex >= parseInt($(#count).text())) {
    pageIndex = tempPageIndex;
    alert(請(qǐng)輸入有效的頁(yè)面范圍!);
    }
    else {
    AjaxGetData($(#txtSearch).val(), pageIndex, pageSize);
    }
    }
    }
    </script>
    同一頁(yè)面HTML代碼:
    jQueryPaging.aspx頁(yè)面的CS代碼如下:
    引用這個(gè)命名空間: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是自己寫的類,表示一條數(shù)據(jù)</cloudfile></cloudfile>
    CloudFile cf = null;
    int cout = 0;
    DataSet ds = LookDataFromDB(name, pageIndex, pageSize,out cout);
    foreach (DataRow row in ds.Tables[0].Rows)//把你的數(shù)據(jù)重新封裝成Lis,才能被jss.Serialize(),不然會(huì)報(bào)錯(cuò)。
    {
    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 ,表示這一頁(yè)從哪一條數(shù)據(jù)開(kāi)始
    // 這里寫自己的數(shù)據(jù)獲取方法,把數(shù)據(jù)獲取好了甩到ds里面,返回到前面。(應(yīng)該有更好的辦法,自己想哦,也可以發(fā)評(píng)論我們一起探討....。)
    }
    catch (Exception)
    {
    cout = 0;
    ds = null;
    }
    return ds;
    }
    代碼如下:
    //<span>CloudFile類</span>
    代碼如下:
    public class CloudFile
    {
    public String FileID { get; set; }
    public String FileName { get; set; }
    public String FileDirName { get; set; }
    }
    這樣一個(gè)簡(jiǎn)單的無(wú)刷新分頁(yè)的實(shí)例就完成了。由于本人的JS水平有限,現(xiàn)在只能做到這了。當(dāng)然還可以添加一些新的功能。這里我只是想將我的方法與大家分享。至于功能,待以后繼續(xù)完善了!??!