欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2014年11月27日 14:16:24   投稿:hebedich  
AJAX(Asynchronous JavaScript and XML)是一種進(jìn)行頁面局部異步刷新的技術(shù)。用AJAX向服務(wù)器發(fā)送請(qǐng)求和獲得服務(wù)器返回的數(shù)據(jù)并且更新到界面中,不是整個(gè)頁面刷新,而是在頁面中使用Js創(chuàng)建XMLHTTPRequest對(duì)象來向服務(wù)器發(fā)出請(qǐng)求以及獲得返回的數(shù)據(jù)。

查詢功能是開發(fā)中最重要的一個(gè)功能,大量數(shù)據(jù)的顯示,我們用的最多的就是分頁。

在ASP.NET 中有很多數(shù)據(jù)展現(xiàn)的控件,比如Repeater、GridView,用的最多的GridView,它同時(shí)也自帶了分頁的功能。但是我們知道用GridView來顯示數(shù)據(jù),如果沒有禁用ViewState,頁面的大小會(huì)是非常的大的。而且平時(shí)我們點(diǎn)擊首頁,下一頁,上一頁,尾頁這些功能都是會(huì)引起頁面回發(fā)的,也就是需要完全跟服務(wù)器進(jìn)行交互,來回響應(yīng)的時(shí)間,傳輸?shù)臄?shù)據(jù)量都是很大的。

AJAX的分頁可以很好的解決這些問題。

數(shù)據(jù)顯示Pasing.aspx頁面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>頁 + </span>;
                htmlStr += 首    頁   ;
                htmlStr += 前一頁   ;
                htmlStr += 后一頁   ;
                htmlStr += 尾    頁   ;
                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);
            }
        });
    }
    //首頁
    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);
    }
    //跳轉(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)輸入有效的頁面范圍!);
            }
            else {
                AjaxGetData($(#txtSearch).val(), pageIndex, pageSize);
            }
        }
    }
</script>

同一頁面HTML代碼:

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

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

//<span style="font-family:">CloudFile類</span>

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

    public class CloudFile
    {
        public String FileID { get; set; }
        public String FileName { get; set; }
        public String FileDirName { get; set; }
    }

這樣一個(gè)簡單的無刷新分頁的實(shí)例就完成了。由于本人的JS水平有限,現(xiàn)在只能做到這了。當(dāng)然還可以添加一些新的功能。這里我只是想將我的方法與大家分享。至于功能,待以后繼續(xù)完善了!??!

相關(guān)文章

  • asp.net使用WebAPI和EF框架結(jié)合實(shí)現(xiàn)數(shù)據(jù)的基本操作

    asp.net使用WebAPI和EF框架結(jié)合實(shí)現(xiàn)數(shù)據(jù)的基本操作

    這篇文章介紹了asp.net使用WebAPI和EF框架結(jié)合實(shí)現(xiàn)數(shù)據(jù)基本操作的案例,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-04-04
  • 一文搞懂MemoryCache 清除全部緩存的方法

    一文搞懂MemoryCache 清除全部緩存的方法

    這篇文章主要介紹了MemoryCache 清除全部緩存的方法,本文給大家介紹兩個(gè)方法,每種方法通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-12-12
  • AJAX JavaScript反射機(jī)制的介紹

    AJAX JavaScript反射機(jī)制的介紹

    反射機(jī)制指的是程序在運(yùn)行時(shí)能夠獲取自身的信息。例如一個(gè)對(duì)象能夠在運(yùn)行時(shí)知道自己有哪些方法和屬性。
    2013-03-03
  • 一步步教你在Asp.net Mvc中使用UEditor編輯器

    一步步教你在Asp.net Mvc中使用UEditor編輯器

    大家都知道ueditor是百度編輯器,目前使用也比較廣泛,下面這篇文章主要是通過一步步的步驟教大家在Asp.net Mvc中使用UEditor編輯器,需要的朋友可以參考借鑒,下面來一起看看吧。
    2016-12-12
  • ASP.NET的適配器設(shè)計(jì)模式(Adapter)應(yīng)用詳解

    ASP.NET的適配器設(shè)計(jì)模式(Adapter)應(yīng)用詳解

    有關(guān)設(shè)計(jì)模式的適配器模式(Adapter)確實(shí)不是很好理解理解,接下來將做一個(gè)簡單的例子簡要說明下,感興趣的朋友可不要錯(cuò)過了哈,希望本文可以幫助到你更好的理解適配器設(shè)計(jì)模式
    2013-02-02
  • .Net6項(xiàng)目部署IIS步驟(圖文)

    .Net6項(xiàng)目部署IIS步驟(圖文)

    本文主要介紹了.Net6項(xiàng)目部署IIS步驟,文中通過圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-04-04
  • asp.net 頁面逐步呈現(xiàn)的方法總結(jié)

    asp.net 頁面逐步呈現(xiàn)的方法總結(jié)

    分塊編碼 ( chunked encoding )就是讓 response 分塊編碼進(jìn)行傳輸。response 分塊編碼,可以先傳輸一部分不需要處理的 html 代碼到客戶端,等其他耗時(shí)代碼執(zhí)行完畢后再傳輸另外的 html 代碼。
    2010-06-06
  • Asp.net中使用PageDataSource分頁實(shí)現(xiàn)代碼

    Asp.net中使用PageDataSource分頁實(shí)現(xiàn)代碼

    這篇文章主要介紹asp.net中使用PageDataSource分頁的方法,需要的朋友可以參考下
    2013-04-04
  • 如何利用IIS調(diào)試ASP.NET網(wǎng)站程序詳解

    如何利用IIS調(diào)試ASP.NET網(wǎng)站程序詳解

    這篇文章主要給大家介紹了關(guān)于如何利用IIS調(diào)試ASP.NET網(wǎng)站程序的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-01-01
  • 在程序中使用Cookie集合(定義/新建/刪除)及案例講解

    在程序中使用Cookie集合(定義/新建/刪除)及案例講解

    在Cookie應(yīng)用中習(xí)慣寫成Cookie集合,什么叫做Cookie集合,即是說一個(gè)Cookie,它擁有多個(gè)值,接下來將介紹怎樣創(chuàng)建Cookie集合與使用,感興趣的朋友可以了解下,希望本文對(duì)你的cookie的深度了解有所幫助
    2013-01-01

最新評(píng)論