亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > .NET > 正文

asp.net使用AJAX實現無刷新分頁

2024-07-10 13:28:34
字體:
來源:轉載
供稿:網友
AJAX(Asynchronous JavaScript and XML)是一種進行頁面局部異步刷新的技術。用AJAX向服務器發送請求和獲得服務器返回的數據并且更新到界面中,不是整個頁面刷新,而是在頁面中使用Js創建XMLHTTPRequest對象來向服務器發出請求以及獲得返回的數據。
 
 

查詢功能是開發中最重要的一個功能,大量數據的顯示,我們用的最多的就是分頁。

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


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩禁在线播放| 亚洲www在线观看| 欧美午夜影院在线视频| 欧美在线播放视频| 亚洲国产天堂久久综合| 97精品视频在线| 亚洲欧美另类在线观看| 精品久久久久久久久久| 久久久在线免费观看| 成人黄色在线播放| 一区二区三区在线播放欧美| 日韩av在线一区二区| 久久成人国产精品| 亚洲国产欧美精品| 69国产精品成人在线播放| 日韩在线一区二区三区免费视频| 国产成人自拍视频在线观看| 午夜精品在线视频| 亚洲一区二区三区sesese| 亚洲免费一级电影| 精品夜色国产国偷在线| 97在线视频观看| 亚洲肉体裸体xxxx137| 亚洲午夜女主播在线直播| 日韩中文字幕不卡视频| 69**夜色精品国产69乱| 欧美多人爱爱视频网站| 91精品国产高清自在线| 国产亚洲人成网站在线观看| 亚洲区中文字幕| 欧美激情中文字幕在线| 亚洲人精品午夜在线观看| 成人黄色av网| 日本精品一区二区三区在线播放视频| 高潮白浆女日韩av免费看| 伊人久久男人天堂| 日韩久久精品电影| 亚洲人成电影网站色xx| 色妞久久福利网| 日韩av123| 91在线中文字幕| 在线观看国产精品日韩av| 久久精品国产免费观看| 日韩电影免费观看中文字幕| 精品国产福利在线| 亚洲天堂男人天堂女人天堂| 91久久国产婷婷一区二区| 国产91免费观看| 青青青国产精品一区二区| 久久这里有精品视频| 日韩av电影国产| 国产精品福利片| 91视频国产高清| 亚洲精品资源在线| 精品成人乱色一区二区| 国产亚洲精品久久久| 亚洲视频日韩精品| 欧美日韩国产在线播放| 国产精品美女主播在线观看纯欲| 国产精品精品一区二区三区午夜版| 色婷婷久久一区二区| 久久成人精品一区二区三区| 欧美激情精品久久久久| 97精品一区二区三区| 久久久亚洲成人| 欧美国产极速在线| 日韩欧美国产高清91| 97视频免费在线看| 色天天综合狠狠色| 青青久久av北条麻妃黑人| 国产91精品黑色丝袜高跟鞋| 日韩在线观看免费网站| 国产精品一区二区av影院萌芽| 国产不卡在线观看| 精品无人区乱码1区2区3区在线| 久久99久久99精品中文字幕| 国产男女猛烈无遮挡91| 日韩高清免费观看| 国产在线精品播放| 色综合男人天堂| 日韩最新免费不卡| 91中文精品字幕在线视频| 国产精品国产亚洲伊人久久| 久久久久久久久久国产| 国产成人啪精品视频免费网| 精品五月天久久| 成人美女av在线直播| 麻豆乱码国产一区二区三区| 久久人人爽人人爽人人片av高清| 国产丝袜视频一区| 欧美日韩不卡合集视频| 国语自产精品视频在免费| 播播国产欧美激情| 亚洲淫片在线视频| 欧美成人高清视频| 欧美激情综合亚洲一二区| 欧美在线视频免费播放| 久久久成人精品视频| 欧美刺激性大交免费视频| 欧美不卡视频一区发布| 国内精品久久影院| 国产精品aaa| 欧美精品一本久久男人的天堂| 中文字幕自拍vr一区二区三区| 久久精品国产精品| 国产成人极品视频| 亚洲精品久久在线| 欧美电影第一页| 国产一区二区精品丝袜| 97激碰免费视频| 性色av一区二区咪爱| 欧美电影免费观看高清完整| 欧洲亚洲妇女av| 色无极影院亚洲| 中文字幕亚洲欧美| 国产精品久久久久久亚洲影视| 欧美精品videossex性护士| 久久成人国产精品| 国产精品免费久久久久影院| 欧美自拍视频在线观看| 精品国产91乱高清在线观看| 亚洲白虎美女被爆操| 国产一区二区三区18| 色偷偷88888欧美精品久久久| 91香蕉电影院| 精品美女永久免费视频| 亚洲第一视频网| 国产成人黄色av| 亚洲黄色www网站| 久久久精品久久久| 一区二区三区高清国产| 亚洲第一视频在线观看| 日韩大陆毛片av| 亚洲第一视频网站| 国产第一区电影| 国产精品老女人精品视频| 久青草国产97香蕉在线视频| 国产精品亚洲综合天堂夜夜| 国产成人在线精品| 久久精品在线视频| 国产午夜精品一区理论片飘花| 亚洲图中文字幕| 欧美性20hd另类| 日韩国产在线看| 欧美性理论片在线观看片免费| 青青在线视频一区二区三区| 国模私拍一区二区三区| 欧美日韩精品在线视频| 亚洲视频在线视频| 亚洲白虎美女被爆操| 免费不卡在线观看av| 欧美日韩在线视频一区二区| 亚洲精品乱码久久久久久按摩观| 国产精品爽爽爽爽爽爽在线观看| 91精品国产综合久久久久久蜜臀| 国产精品亚洲视频在线观看| 国产精品偷伦免费视频观看的| 97婷婷大伊香蕉精品视频| 精品自拍视频在线观看| 国产精品色午夜在线观看| 日韩av在线免费看| 久久久久这里只有精品| 国产精品视频免费在线观看| 黄色一区二区在线|