无刷新分页 Ajax,JQuery,Json
1.数据库设计
字段:Id(int) , Msg(varchar(MAX)) , PostDate(datetime)
2.自定义SQL查询方法(强类型DataSet)
//SelectCount()方法,用于查询总条数
select count(*) from T_Posts
//GetPageData(startRowIndex,endRowIndex)方法,用于查询指定范围,分页功能,
由于不支持over语句,因此需手动增加参数,方法-右键-属性,里面的 Parameters
增加startRowIndex 和 endRowIndex,类型为 Int32
select * from
(
select Id, Msg,PostDate,Row_Number()over(order by PostDate)rownum from T_Posts
)t
where t.rownum>=@startRowIndex and t.rownum<=@endRowIndex
3.HTML设置
<ul id="ulComment"></ul>
<table>
<tr id="trPage"></tr>
</table>
4.处理页设置 WSXFY.ashx
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
string action = context.Request["action"]; //取得客户提交上来的 action 值
if (action == "getpagecount") //此为查询数据总条数
{
var adapter = new T_PostsTableAdapter();
int count = adapter.SelectCount().Value; //利用自定义SQL方法得到条数
int pagecount = count / ; //条数除以10,得到页数(10条一页)
if (count % != ) //取条数的余数,没有被10整除的,都加1
{
pagecount++;
}
context.Response.Write(pagecount); //输出页数 }
else if(action == "getpagedata") //此为查询详细数据
{
string pagenum = context.Request["pagenum"]; //得到当前页号
int PageNum = Convert.ToInt32(pagenum); //转换成INT型
var adapter = new T_PostsTableAdapter(); //创建DataSet
var data = adapter.GetPageData((PageNum - ) * + ,(PageNum) * );
//使用自定义SQL方法,得到条数范围
List<Comment> list = new List<Comment>(); //创建List类型为Comment
foreach (var row in data) //遍历每一条数据
{
list.Add(new Comment() { Msg = row.Msg, PostDate = row.PostDate.ToShortDateString() });
//将每条数据都增加到List中
}
JavaScriptSerializer jss = new JavaScriptSerializer(); //创建 Json
context.Response.Write(jss.Serialize(list)); //将list转换成Json类型
}
}
public class Comment //创建一个类
{
public string Msg { get; set; }
public string PostDate { get; set; }
}
5. Javascript设置
<script type="text/javascript">
$.post("WSXFY.ashx", { "action": "getpagecount" }, function(data, status) {
for (var i = 1; i <= data; i++) {
var td = $("<td><a href=''>" + i + "</a></td>"); //循环输出页号
$("#trPage").append(td); //将每一个td都附加上去
}
$("#trPage td").click(function(e) {
e.preventDefault(); //阻止执行 href 的地址
$.post("WSXFY.ashx", { "action": "getpagedata", "pagenum": $(this).text() },
function(data, status) {
var comments = $.parseJSON(data); //利用 parseJSON 转换
$("#ulComment").empty(); //清空ul
for (var i = 0; i < comments.length; i++) {
var comment = comments[i];
var li = $("<li>" + comment.PostDate + ":" + comment.Msg + "</li>"); //生成数据
$("#ulComment").append(li);
}
});
});
});
</script>
无刷新分页 Ajax,JQuery,Json的更多相关文章
- 无刷新删除 Ajax,JQuery
1.数据库用上面的,增加一个 DeleteById 的SQL方法 delete from T_Posts where Id = @Original_Id 2.设置处理页面 delete.ashx pu ...
- 无刷新分页 jquery.pagination.js
无刷新分页 jquery.pagination.js 采用Jquery无刷新分页插件jquery.pagination.js实现无刷新分页效果 1.插件参数列表 http://www.dtan.so ...
- jquery ajax php+mysql 无刷新分页 详细实例
最近在接触jquery和ajax,当前项目也会用到分页,为了用户体验更好一些,就准备用无刷新分页,这个demo很适合新手学习查看,写的比较清晰,话不多说,直接上代码吧. 首先是html页面,index ...
- javascript;Jquery;获取JSON对象,无刷新分页,异步加载,异步删除,实例。
AjaxNewsList: <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> < ...
- thinkphp ajax 无刷新分页效果的实现
思路:先做出传统分页效果,然后重新复制一份Page.class.php类,对它进行修改,把js中的函数传到page类中,把上一页.下一页.首页.尾页.链接页中的url地址改成js控制的函数,模板页面中 ...
- ASP.NET Ajax简单的无刷新分页
最近练习了一些AJAX无刷新分页,写得比较简单,性能不知道怎么样,求大神指点,如有更好的分页提供,欢迎交流! 发话不多说了,直接上代码! 首先从网上下了一个JS分页,感觉挺好用的 (function( ...
- TP2.0或3.1 或者 3.2 下使用ajax+php做无刷新分页(转+自创)
1.前言 作为一名php程序员,我们开发网站主要就是为了客户从客户端进行体验,在这里,thinkphp框架自带的分页类是每次翻页都要刷新一下整个页面,这种翻页的用户体验显然是不太理想的,我们希望每次翻 ...
- ajax 无刷新分页
//ajax 无刷新分页1.前台要做的 滑动时 当前page+1,通过page ajax请求后台接口获取数据将数据进行拼装;2.后台要做的 做分页接口返回json数据前台判断触发请求条件: var p ...
- 学习笔记之AJAX无刷新分页
利用AJAX实现无刷新分页技术原理: 其主要是利用AJAX的异步处理机制,实现数据的异步传递,它隐藏了客户端向服务端请求数据的状态,在客户端表现为无刷新的显示状态. 实现分页的步骤: 1.客服端点击页 ...
随机推荐
- poj 2117 Electricity【点双连通求删除点后最多的bcc数】
Electricity Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 4727 Accepted: 1561 Descr ...
- JS 单元测试
JS单元测试,我工作时主要以mocha + chai 下面时具体的文档: mocha: https://mochajs.org/#asynchronous-code Chai: http://chai ...
- GPUImage的简单使用
GPUImage 是一个开源的图像处理库,提供了非常多的滤镜效果来加工图片.GPUImage 并不像一般的第三方库可以直接拖入到工程中使用,而是需要先在本地编译,然后将编译后的文件拖入到工程中使用.配 ...
- DevExpress GridControl 显示行号、设置行号宽
显示行号类 /// <summary> /// GridView 显示行号 设置行号列的宽度 /// </summary> /// <param name="g ...
- SVN的配置与调试
- 从BAE到SAE,从SAE又回到BAE
版权声明:本文为博主原创文章,未经博主允许不得转载. [很久以后] 这段话是很久之后补充的,发现错误要勇于改正,以下红色字体是对以前观点的改正, 大概总结下: 1.bae最大缺点是需要备案,不过现在看 ...
- SignalR安装以及安装问题
正常节奏 介绍 SignalR 是 ASP.NET 团队正在开发的一个 Microsoft .NET Framework 库和 jQuery 插件,可能包括在以后版本的 ASP.NET 平台中. 它提 ...
- 理解URI和URL
1)定义: URI: Uniform Resource Identifier,通用资源标识符 ---是一个用于标识某一互联网资源名称的字符串(by 维基百科) URL:Uniform Resource ...
- redis持久化(摘录)
redis是一个支持持久化的内存数据库,也就是说redis需要经常将内存中的数据同步到磁盘来保证持久化.redis支持两种持久化方式,一种是 Snapshotting(快照)也是默认方式,另一种是Ap ...
- android学习笔记之ImageView的scaleType属性
我们知道,ImageView有一个属性叫做scaleType,它的取值一共有八种,分别是:matrix,fitXY,fitStart,fitCenter,fitEnd,center,centerCro ...