手机
当前位置:查字典教程网 >编程开发 >asp.net教程 >asp.net 无刷新分页实例代码
asp.net 无刷新分页实例代码
摘要:数据类代码:复制代码代码如下:usingSystem;usingSystem.Collections.Generic;usingSystem...

数据类代码:

复制代码 代码如下:

using System;

using System.Collections.Generic;

using System.Linq;

using System.Text;

using System.Data;

using System.Data.SqlClient;

using System.Collections;

using System.Reflection;

namespace DAL

{

public class UserManageClass

{

/// <summary>

/// 取得总页数

/// </summary>

/// <returns>总页数</returns>

public int GetPageCount()

{

int counts;

string SqlStr = "select count(0) from [User]";

counts = new SQLHelper().Content(SqlStr, CommandType.Text);

return counts;

}

/// <summary>

/// 取出每一页的内容

/// </summary>

/// <param name="SatrPage">开始页数</param>

/// <param name="EndPage">结束页数</param>

/// <returns>每一页的内容</returns>

public DataTable GetPageDate(string SatrPage, string EndPage)

{

DataTable dt;

string SqlStr = @"select * from

(select *, ROW_NUMBER() over(order by id)as no_ from [User])aa

where aa.no_ between '"+SatrPage+"' and '"+EndPage+"'";

dt = new SQLHelper().ExecuteQuery(SqlStr, CommandType.Text);

return dt;

}

/// <summary>

/// 将一个DataTable转换成列表

/// </summary>

/// <typeparam name="T">实体对象的类型</typeparam>

/// <param name="dt">要转换的DataTable</param>

/// <returns></returns>

public List<T> DataTableToEntityList<T>(DataTable dt)

{

List<T> entiyList = new List<T>();

Type entityType = typeof(T);

PropertyInfo[] entityProperties = entityType.GetProperties();

foreach (DataRow row in dt.Rows)

{

T entity = Activator.CreateInstance<T>();

foreach (PropertyInfo propInfo in entityProperties)

{

if (dt.Columns.Contains(propInfo.Name))

{

if (!row.IsNull(propInfo.Name))

{

propInfo.SetValue(entity, row[propInfo.Name], null);

}

}

}

entiyList.Add(entity);

}

return entiyList;

}

}

}

PageService.ashx.cs一般处理程序代码:

复制代码 代码如下:

using System;

using System.Collections;

using System.Data;

using System.Linq;

using System.Web;

using System.Web.Services;

using System.Web.Services.Protocols;

using System.Xml.Linq;

using System.Data.SqlClient;

using DAL;

using System.Web.Extensions;

using System.Web.Script.Serialization;

using Model;

using System.Web.UI.MobileControls;

using System.Collections.Generic;

namespace LandingSystem

{

/// <summary>

/// $codebehindclassname$ 的摘要说明

/// </summary>

[WebService(Namespace = "http://tempuri.org/")]

[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]

public class PageService : IHttpHandler

{

public void ProcessRequest(HttpContext context)

{

context.Response.ContentType = "text/plain";

string action = context.Request["action"];

if (action == "GetPageCount")

{

int counts = new UserManageClass().GetPageCount();

int page = counts / 3;

if (counts % 3 != 0)

{

page++;

}

context.Response.Write(page);

}

else if (action == "GetPageData")

{

int pageNo = Convert.ToInt32(context.Request["PageNo"]);

string SatrPage = ((pageNo - 1) * 3 + 1).ToString();

string EndPage = (pageNo * 3).ToString();

DataTable dt= new UserManageClass().GetPageDate(SatrPage, EndPage);

IList<RegisterModel> data = ModelConvertHelper<RegisterModel>.ConvertToModel(dt);

// IList<RegisterModel> data = new UserManageClass().DataTableToEntityList<RegisterModel>(dt);

var p1 = data.Select(c => new { c.Name,c.Phone});

#region 废物代码

// var p1 = data.Select( c => new { c.Name,c.Phone});

//var p1=data.Select(dr=>new {dr["Name"].ToString(),dr["Phone"].ToString()});

//var T_model = new List<RegisterModel>();

//var p3 = T_model.Select(c => new { c.Name, c.Phone });

//var p2=data.Select(c=>new {})

#endregion

JavaScriptSerializer jss = new JavaScriptSerializer();

context.Response.Write(jss.Serialize(p1));

}

}

public bool IsReusable

{

get

{

return false;

}

}

}

}

aspx页面代码:

复制代码 代码如下:

<head runat="server">

<title>无标题页</title>

<script src="JS/jquery-latest.js" type="text/javascript"></script>

<script type="text/javascript">

$(function(){

//-----------------------------------------------------------

function getPageData(pageNo){ //取得某页数据的方法

$.post("PageService.ashx",{"action":"GetPageData","PageNo":pageNo},function(data,status){

if(status=="success"){

$("#Comment").empty();

var comments=$.parseJSON(data); //反序列化json数据。

for(var i=0;i<comments.length;i++){

var row=comments[i];

var li= $("<li>"+row.Name+" : "+row.Phone+"</li>");

$("#Comment").append(li); //每取出一条数据就创建一个li并append到Comment/ul内。

}

}

});

}

//-------------------------------------------------------------------

getPageData(1); //首次进入页面,看到的是第一页的数据

//----------------------------------------------------------------/

//取得所有的页数并且初始化分页按钮

$.post("PageService.ashx",{"action":"GetPageCount"},function(data,status){

if(status=="success"){

var tr1=$("<tr></tr>");

var pageNo=parseInt(data);

for(var i=1;i<=pageNo;i++){

var td=$("<td><a href=''>"+i+"</a></td>");

tr1.append(td);

}

$("#pageNo").append(tr1);

$("#pageNo a").click(function(e){ //页码创建后,就为每一个页码监听一个click事件。

e.preventDefault(); //取消a的默认跳转行为

getPageData($(this).html()); //点击后就去执行取页数据的操作。

});

}

});

//----------------------------------------------------------------------------

});

</script>

</head>

<body>

<table>

<tr>

<td>

<ul id="Comment"></ul>

</td>

</tr>

</table>

<br />

页数:

<table id="pageNo"></table>

</body>

</html>

ModelConvertHelper.cs(将datatable转换为list通用类)代码:

复制代码 代码如下:

using System;

using System.Collections.Generic;

using System.Linq;

using System.Text;

using System.Collections;

using System.Data;

using System.Reflection;

namespace DAL

{

public class ModelConvertHelper<T> where T : new ()

{

public static IList<T> ConvertToModel(DataTable dt)

{

IList<T> ts = new List<T>();

Type type=typeof(T);

string tempName = "";

foreach (DataRow dr in dt.Rows)

{

T t = new T();

// 获得此模型的公共属性

PropertyInfo[] propertys = t.GetType().GetProperties();

foreach (PropertyInfo pi in propertys)

{

tempName = pi.Name;

// 检查DataTable是否包含此列

if (dt.Columns.Contains(tempName))

{

// 判断此属性是否有Setter

if (!pi.CanRead) continue;

object value = dr[tempName];

if (value != DBNull.Value)

if (pi.PropertyType == typeof(int))

{

pi.SetValue(t, Convert.ToInt32(value), null);

}

else if (pi.PropertyType == typeof(string))

{

pi.SetValue(t, value.ToString(), null);

}

//pi.SetValue(t, value, null);

}

}

ts.Add(t);

}

return ts;

}

}

}

【asp.net 无刷新分页实例代码】相关文章:

asp.net AJAX实现无刷新获得数据

jsp和asp.net共享session值示例代码

asp.net文件上传示例

asp.net(C#)生成Code39条形码实例

asp.net自定义控件代码学习笔记

asp.net 文件下载实现代码

Asp.net 无限级分类实例代码

asp.net操作xml增删改示例分享

ASP.net 验证码实现代码(C#)

asp.net(c#) 水仙花数

精品推荐
分类导航