主頁(yè) > 知識(shí)庫(kù) > asp.net使用AJAX實(shí)現(xiàn)無(wú)刷新分頁(yè)

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

熱門(mén)標(biāo)簽:百度AI接口 電商新玩法 網(wǎng)站排名優(yōu)化 國(guó)美全國(guó)運(yùn)營(yíng)中心 電銷(xiāo)業(yè)務(wù) 客戶(hù)服務(wù) 科大訊飛語(yǔ)音識(shí)別系統(tǒng) 人工智能

查詢(xún)功能是開(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代碼:  

復(fù)制代碼 代碼如下:

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);//重寫(xiě)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要用的。

復(fù)制代碼 代碼如下:

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;
            IListcloudfile> cloudfileLists = new Listcloudfile>();//cloudfile是自己寫(xiě)的類(lèi),表示一條數(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)始
       // 這里寫(xiě)自己的數(shù)據(jù)獲取方法,把數(shù)據(jù)獲取好了甩到ds里面,返回到前面。(應(yīng)該有更好的辦法,自己想哦,也可以發(fā)評(píng)論我們一起探討....。)
    }
    catch (Exception)
    {
        cout = 0;
        ds = null;
    }
    return ds;
}

復(fù)制代碼 代碼如下:

//span style="font-family:">CloudFile類(lèi)/span>

復(fù)制代碼 代碼如下:

    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ù)完善了?。。?/p>

您可能感興趣的文章:
  • asp.net中MVC借助Iframe實(shí)現(xiàn)無(wú)刷新上傳文件實(shí)例
  • asp.net中Timer無(wú)刷新定時(shí)器的實(shí)現(xiàn)方法
  • asp.net中利用Jquery+Ajax+Json實(shí)現(xiàn)無(wú)刷新分頁(yè)的實(shí)例代碼
  • Asp.Net 無(wú)刷新文件上傳并顯示進(jìn)度條的實(shí)現(xiàn)方法及思路
  • asp.net+jquery ajax無(wú)刷新登錄的實(shí)現(xiàn)方法
  • Asp.net 2.0 無(wú)刷新圖片上傳 顯示縮略圖 具體實(shí)現(xiàn)
  • asp.net jquery無(wú)刷新分頁(yè)插件(jquery.pagination.js)
  • asp.net Ajax之無(wú)刷新評(píng)論介紹
  • asp.net點(diǎn)擊 查看更多 實(shí)現(xiàn)無(wú)刷新加載的實(shí)現(xiàn)代碼
  • asp.net 簡(jiǎn)便無(wú)刷新文件上傳系統(tǒng)
  • asp.net ajax實(shí)現(xiàn)無(wú)刷新驗(yàn)證碼
  • asp.net 30分鐘掌握無(wú)刷新 Repeater
  • asp.net下使用jquery 的ajax+WebService+json 實(shí)現(xiàn)無(wú)刷新取后臺(tái)值的實(shí)現(xiàn)代碼
  • Asp.net實(shí)現(xiàn)無(wú)刷新調(diào)用后臺(tái)實(shí)體類(lèi)數(shù)據(jù)并以Json格式返回

標(biāo)簽:POS機(jī) 南平 廈門(mén) 棗莊 攀枝花 益陽(yáng) 咸寧 拉薩

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《asp.net使用AJAX實(shí)現(xiàn)無(wú)刷新分頁(yè)》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢(xún)

    • 400-1100-266