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

jquery+json實現(xiàn)分頁效果

 更新時間:2016年03月07日 11:32:18   作者:黃金地帶  
這篇文章主要為大家詳細介紹了如何利用jquery結合json實現(xiàn)分頁效果,感興趣的小伙伴們可以參考一下

Json作為一種輕量級的數(shù)據(jù)交換格式,由于其傳輸數(shù)據(jù)格式的方便性,今天偶然想將其應用于分頁實現(xiàn),分頁做為web開發(fā)一個長久的話題,其應用的高效與重要性就不多說了
本文主要技術:反射機制,Json數(shù)據(jù)格式,jquery
為了應用的通用性,首先要根據(jù)反射機制,能將要返回的任意類型的結果對象轉化成Json類型的格式。

public static String toJSON(Object obj) {
HashMap map = new HashMap();
Class c = obj.getClass();
// 利用反射機 制,把里面所有的屬性,反射出來使用,這樣放入任何一個對象, 都可以找到他們的屬性,
// 把這些屬性的名,和屬性的值,封裝成一個map里,
Field[] fields = c.getDeclaredFields();
for (int i = 0; i < fields.length; i++) {
String name = fields[i].getName();
try {
fields[i].setAccessible(true);
Object o = fields[i].get(obj);
i f (o instanceof Number) {
map.put(""" + name + """, o.toString());
} else if (o instanceof String) {
map.put(""" + name + """, """ + o.toString() + """);
}
} catch (IllegalArgumentException e) {
} catch (IllegalAccessException e) {
}
}
/ / 把map對象變成字符串
// 這些格式還需要把=變成:
String s = map.toString();
/ /System.out.println(s);
String str = s.replaceAll(""=", "":");
//System.out.println(str);
return str;
}

將要返回的多個對象轉換成Json類型的對象后,最后應加上分頁的信息,最終將多個Json字符串,轉化成一整個Json類型

{"0":{"id":"0", "name":"dong0", "age":21},
"1":{"id":"1", "name":"dong1", "age":21},
"2":{"id":"2", "name":"dong2", "age":21},
"3":{"id":"3", "name":"dong3", "age":21},
"4":{"id":"4", "name":"dong4", "age":21},
"5":{"id":"5", "name":"dong5", "age":21},
"6":{"id":"6", "name":"dong6", "age":21},
"7":{"id":"7", "name":"dong7", "age":21},
"8":{"id":"8", "name":"dong8", "age":21},
"9":{"id":"9", "name":"dong9", "age":21},
"10":{"firstPage":1, "currentPage":1, 
"default_Record_Num":10, "lastPage":10, "frontPage":1, "sum":100, "nextPage":2},
"length":11}

當信息發(fā)送到客戶端時 ,只用jquery接收對象的數(shù)據(jù)就行了 ,這樣 可以實現(xiàn)前臺的樣式與后臺傳送的數(shù)據(jù)分離,更加簡化了代碼

$.getJSON("result.jsp?page="+p, function(json)
{
$("#show").html("<tr><th>用戶ID</th><th>用戶名</th><th>用戶年齡</th></tr>");
for(var i=0 ; i<json.length-1; i++){
$("#show").append("<tr><td>"+json[i]["id"]+"</td><td>"+json[i]["name"]+"</ td><td>"
+json[i]["age"]+"</td></tr>");
}
$("#currentPage").attr("value",json[json.length-1]["currentPage"]);
$("#pageCount").attr("value",json[json.length-1]["lastPage"]);
});

利用JQuery與JSon實現(xiàn)的無刷新分頁代碼,具體代碼如下

需要四個文件
一個實體類文件 CategoryInfoModel.cs
一個SqlHelper SQLHelper.cs
一個AJAX服務端處理程序 PagedService.ashx
一個客戶端調(diào)用頁面 WSXFY.htm
CategoryInfoModel.cs和SQLHelper.cs我就不寫了,都知道是什么文件
PagedService.ashx 代碼如下

using System.Web.Script.Serialization; 
public void ProcessRequest(HttpContext context) 
{ 
context.Response.ContentType = "text/plain"; 
string strAction = context.Request["Action"]; 
//取頁數(shù) 
if (strAction == "GetPageCount") 
{ 
string strSQL = "SELECT COUNT(*) FROM CategoryInfo"; 
int intRecordCount = SqlHelper.ExecuteScalar(strSQL); 
int intPageCount = intRecordCount / 10; 
if (intRecordCount % 10 != 0) 
{ 
intPageCount++; 
} 
context.Response.Write(intPageCount); 
}//取每頁數(shù)據(jù) 
else if (strAction == "GetPageData") 
{ 
string strPageNum = context.Request["PageNum"]; 
int intPageNum = Convert.ToInt32(strPageNum); 
int intStartRowIndex = (intPageNum - 1) * 10 + 1; 
int intEndRowIndex = (intPageNum) * 10 + 1; 
string strSQL = "SELECT * FROM ( SELECT ID,CategoryName,Row_Number() OVER(ORDER BY ID ASC) AS rownum FROM CategoryInfo) AS t"; 
strSQL += " WHERE t.rownum >= " + intStartRowIndex + " AND t.rownum <= " + intEndRowIndex; 
DataSet ds = new DataSet(); 
SqlConnection conn = SqlHelper.GetConnection(); 
ds = SqlHelper.ExecuteDataset(conn, CommandType.Text, strSQL); 
List<CategoryInfoModel> categoryinfo_list = new List<CategoryInfoModel>();//定義實體集合 
for (int i = 0; i < ds.Tables[0].Rows.Count; i++) 
{ 
CategoryInfoModel categoryinfo = new CategoryInfoModel(); 
categoryinfo.CategoryInfoID = Convert.ToInt32(ds.Tables[0].Rows[i]["ID"]); 
categoryinfo.CategoryName = ds.Tables[0].Rows[i]["CategoryName"].ToString(); 
categoryinfo_list.Add(categoryinfo); 
} 
JavaScriptSerializer jss = new JavaScriptSerializer(); 
context.Response.Write(jss.Serialize(categoryinfo_list));//序列化實體集合為javascript對象 
} 
} 

WSXFY.htm 代碼如下

<head> 
<title>無刷新分頁</title> 
<script type="text/javascript" src="../Scripts/jquery-1.5.1.min.js"></script> 
<script type="text/javascript"> 
$(function () { 
$.post("PagedService.ashx", { "Action": "GetPageCount" }, function (response, status) { 
for (var i = 1; i <= response; i++) { 
var td = $("<td><a href=''>" + i + "</a></td>"); 
$("#trPage").append(td); 
td.click(function (e) { 
e.preventDefault(); //不要導向鏈接 
$.post("PagedService.ashx", { "Action": "GetPageData", "PageNum":$(this).text() }, function (response, status) { 
var categorys = $.parseJSON(response); 
$("#ulCategory").empty(); 
for (var i = 0; i < categorys.length; i++) { 
var category = categorys[i]; 
var li = $("<li>" + category.CategoryInfoID + "-" + category.CategoryName + "</li>"); 
$("#ulCategory").append(li); 
} 
}); 
}); 
} 
}); 
}); 
</script> 
</head> 
<body> 
<ul id="ulCategory"></ul> 
<table> 
<tr id="trPage"> 
</tr> 
</table> 
</body> 
</html> 

以上就是本文的全部內(nèi)容,希望能夠幫助大家實現(xiàn)分頁效果。

相關文章

  • 自己動手制作基于jQuery的Web頁面加載進度條插件

    自己動手制作基于jQuery的Web頁面加載進度條插件

    進度條插件在GitHub上多種多樣數(shù)量繁多,這總結出頁面進度條插件的實現(xiàn)要點,來教大家自己動手制作基于jQuery的Web頁面加載進度條插件
    2016-06-06
  • jquery.cookie用法詳細解析

    jquery.cookie用法詳細解析

    本篇文章主要是對jquery.cookie的用法進行了詳細的分析介紹,需要的朋友可以過來參考下,希望對大家有所幫助
    2013-12-12
  • js/jquery判斷瀏覽器的方法小結

    js/jquery判斷瀏覽器的方法小結

    在網(wǎng)站前端開發(fā)中,瀏覽器兼容性是前端開發(fā)框架要解決的第一個問題,要解決兼容性問題就得首先準確判斷出瀏覽器的類型及其版本,而判斷瀏覽器的版本一般只能通過分析瀏覽器的userAgent才能知道.今天我們把各種判斷方法都總結一下,希望對大家有所幫助
    2014-09-09
  • Jquery easyui 實現(xiàn)動態(tài)樹

    Jquery easyui 實現(xiàn)動態(tài)樹

    本文給大家介紹jquery easyui實現(xiàn)動態(tài)樹,本文通過代碼實例相結合的方式給大家展示jquery easyui實現(xiàn)動態(tài)樹的過程,感興趣的朋友一起學習吧
    2015-11-11
  • Jquery焦點圖實例代碼

    Jquery焦點圖實例代碼

    這篇文章主要介紹了Jquery焦點圖實例代碼,詳細講述了使用jQuery實現(xiàn)焦點圖的詳細步驟,代碼中備有較為詳盡的注釋說明,便于大家理解,需要的朋友可以參考下
    2014-11-11
  • JQUERY 獲取IFrame中對象及獲取其父窗口中對象示例

    JQUERY 獲取IFrame中對象及獲取其父窗口中對象示例

    經(jīng)常會用到iframe,難免會碰到需要在父窗口中使用iframe中的元素、或者在iframe框架中使用父窗口的元素,下面為大家簡單介紹下本人的使用心得
    2013-08-08
  • jQuery插件FusionWidgets實現(xiàn)的AngularGauge圖效果示例【附demo源碼】

    jQuery插件FusionWidgets實現(xiàn)的AngularGauge圖效果示例【附demo源碼】

    這篇文章主要介紹了jQuery插件FusionWidgets實現(xiàn)的AngularGauge圖效果,結合具體實例形式分析了jQuery使用FusionWidgets插件載入xml數(shù)據(jù)實現(xiàn)AngularGauge圖的相關操作技巧,并附帶demo源碼供讀者下載參考,需要的朋友可以參考下
    2017-03-03
  • jquery下異步提交表單 異步跨域提交表單

    jquery下異步提交表單 異步跨域提交表單

    基于jquery的實現(xiàn)異步跨域提交表單的實現(xiàn)代碼,需要的朋友可以參考下。
    2010-11-11
  • jQuery Selectors(選擇器)的使用(七、子元素篇)

    jQuery Selectors(選擇器)的使用(七、子元素篇)

    本系列文章主要講述jQuery框架的選擇器(Selectors)使用方法,我將以實例方式進行講述,以簡單,全面為基礎,不會涉及很深,我的學習方法:先入門,后進階!
    2009-12-12
  • jQuery實現(xiàn)手機上輸入后隱藏鍵盤功能

    jQuery實現(xiàn)手機上輸入后隱藏鍵盤功能

    最近做了這樣一個功能,讓用戶輸入手機發(fā)送驗證碼,輸完11位手機號后,自動隱藏鍵盤。下面通過本文給大家分享實現(xiàn)方法,一起看看吧
    2017-01-01

最新評論