查询功能是开发中最重要的一个功能,大量数据的显示,我们用的最多的就是分页。
在ASP.NET 中有很多数据展现的控件,比如Repeater、GridView,用的最多的GridView,它同时也自带了分页的功能。但是我们知道用GridView来显示数据,如果没有禁用ViewState,页面的大小会是非常的大的。而且平时我们点击首页,下一页,上一页,尾页这些功能都是会引起页面回发的,也就是需要完全跟服务器进行交互,来回响应的时间,传输的数据量都是很大的。
AJAX的分页可以很好的解决这些问题。
数据显示Pasing.aspx页面JS代码:
同一页面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 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;
}
//CloudFile类
public class CloudFile
{
public String FileID { get; set; }
public String FileName { get; set; }
public String FileDirName { get; set; }
}
这样一个简单的无刷新分页的实例就完成了。由于本人的JS水平有限,现在只能做到这了。当然还可以添加一些新的功能。这里我只是想将我的方法与大家分享。至于功能,待以后继续完善了!!!
- asp.net中MVC借助Iframe实现无刷新上传文件实例
- asp.net中Timer无刷新定时器的实现方法
- asp.net中利用Jquery+Ajax+Json实现无刷新分页的实例代码
- Asp.Net 无刷新文件上传并显示进度条的实现方法及思路
- asp.net+jquery ajax无刷新登录的实现方法
- Asp.net 2.0 无刷新图片上传 显示缩略图 具体实现
- asp.net jquery无刷新分页插件(jquery.pagination.js)
- asp.net Ajax之无刷新评论介绍
- asp.net点击 查看更多 实现无刷新加载的实现代码
- asp.net 简便无刷新文件上传系统
- asp.net ajax实现无刷新验证码
- asp.net 30分钟掌握无刷新 Repeater
- asp.net下使用jquery 的ajax+WebService+json 实现无刷新取后台值的实现代码
- Asp.net实现无刷新调用后台实体类数据并以Json格式返回