asp.net使用AJAX實(shí)現(xiàn)無(wú)刷新分頁(yè)
來(lái)源:易賢網(wǎng) 閱讀:652 次 日期:2014-12-01 11:39:43
溫馨提示:易賢網(wǎng)小編為您整理了“asp.net使用AJAX實(shí)現(xiàn)無(wú)刷新分頁(yè)”,方便廣大網(wǎng)友查閱!

查詢功能是開發(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ù)開始

// 這里寫自己的數(shù)據(jù)獲取方法,把數(shù)據(jù)獲取好了甩到ds里面,返回到前面。(應(yīng)該有更好的辦法,自己想哦,也可以發(fā)評(píng)論我們一起探討....。)

}

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; }

}

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

更多信息請(qǐng)查看IT技術(shù)專欄

更多信息請(qǐng)查看網(wǎng)絡(luò)編程
易賢網(wǎng)手機(jī)網(wǎng)站地址:asp.net使用AJAX實(shí)現(xiàn)無(wú)刷新分頁(yè)
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

2025國(guó)考·省考課程試聽(tīng)報(bào)名

  • 報(bào)班類型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢 | 簡(jiǎn)要咨詢須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
云南網(wǎng)警備案專用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號(hào):hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專用圖標(biāo)