学习笔记之AJAX无刷新分页
利用AJAX实现无刷新分页技术原理:
其主要是利用AJAX的异步处理机制,实现数据的异步传递,它隐藏了客户端向服务端请求数据的状态,在客户端表现为无刷新的显示状态。
实现分页的步骤:
1.客服端点击页码按钮触发分页事件
2.客户端传递页码参数到服务端
3.服务端连接数据库获取数据
4.服务端将数据序列化并写入输出流
5.客户端获取输出流,并转换为JSON格式数据
6.将JSON数据组合排列到标签元素生成具体页面。
具体实例:
ASPX页面代码
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
<script type="text/javascript" src="jquery-1.4.1.js"></script>
<script type="text/javascript">
var pageCount = 0;
var pageIndex = 1;
$(function () {
//getdata
$.post("Pager.ashx", { "data": "getdata", "count": "1" }, function (data, status) {
var dd = $.parseJSON(data);
$(".con li").remove();
for (var i = 0; i < dd.length; i++) {
var li = $("<li>" + dd[i].datetime + ":" + dd[i].Msg + "</li>");
$(".con").append(li);
}
});
//getdatacount
$.post("Pager.ashx", { "data": "getcount" }, function (data, status) {
//alert(data);
pageCount = data;
$(".b").text(data);
});
//尾页
$(".pp li:eq(0) a").click(function (e) {
e.preventDefault();
$.post("Pager.ashx", { "data": "getdata", "pagecount": pageCount }, function (data, status) {
var dd = $.parseJSON(data);
$(".con li").remove();
for (var i = 0; i < dd.length; i++) {
var li = $("<li>" + dd[i].datetime + ":" + dd[i].Msg + "</li>");
$(".con").append(li);
}
});
});
//下页
$(".pp li:eq(1) a").click(function (e) {
e.preventDefault();
if (pageIndex < pageCount) {
pageIndex++;
$.post("Pager.ashx", { "data": "getdata", "pagecount": pageIndex }, function (data, status) {
var dd = $.parseJSON(data);
$(".con li").remove();
for (var i = 0; i < dd.length; i++) {
var li = $("<li>" + dd[i].datetime + ":" + dd[i].Msg + "</li>");
$(".con").append(li);
}
});
}
});
//上一页
$(".pp li:eq(2) a").click(function (e) {
e.preventDefault();
if (pageIndex > 1) {
pageIndex--;
$.post("Pager.ashx", { "data": "getdata", "pagecount": pageIndex }, function (data, status) {
var dd = $.parseJSON(data);
$(".con li").remove();
for (var i = 0; i < dd.length; i++) {
var li = $("<li>" + dd[i].datetime + ":" + dd[i].Msg + "</li>");
$(".con").append(li);
}
});
}
});
//首页
$(".pp li:eq(3) a").click(function (e) {
e.preventDefault();
pageIndex = 1;
$.post("Pager.ashx", { "data": "getdata", "pagecount": pageIndex }, function (data, status) {
var dd = $.parseJSON(data);
$(".con li").remove();
for (var i = 0; i < dd.length; i++) {
var li = $("<li>" + dd[i].datetime + ":" + dd[i].Msg + "</li>");
$(".con").append(li);
}
});
});
})
</script>
<style type="text/css">
li{ float:right; margin:0 2px 0; list-style:none;}
.page{float:right; margin-right:1em;}
.content{ clear:both;}
.con li{ float:none; list-style:none; background-color:Gray;}
a{ cursor:pointer;}
.con
{
width: 400px;
}
</style>
</head>
<body>
<form id="form1" runat="server">
<div class="content" style=" width:600px; height:400px; border:1px solid red;">
<ul class="con"></ul>
</div>
<div>
<ul class="pp">
<li><a>尾页</a></li>
<li><a>下一页</a></li>
<li><a>上一页</a></li>
<li><a>首页</a></li>
<li><div class="page">共有数据:<span class="b"></span></div></li>
</ul>
</div>
</form>
</body>
</html>
后台处理程序ashx
<%@ WebHandler Language="C#" class="Pager" %>
using System;
using System.Web;
using System.Collections.Generic;
using System.Web.Script.Serialization;
using System.Data;
using System.Data.SqlClient;
using System.Text;
public class Pager : IHttpHandler {
public void ProcessRequest (HttpContext context) {
context.Response.ContentType = "text/plain";
string paras = context.Request.Params["data"].ToString();
//string pagecount = ;
if (paras == "getcount")
{
fenyeSlect ff = new fenyeSlect();
DataTable dt = ff.selectCount().Tables[0];
int count = Convert.ToInt32(dt.Rows[0][0].ToString());
int pageCount = count / 10;
if (count % 10 != 0)
{
pageCount++;
}
context.Response.Write(pageCount);
}
else if (paras == "getdata")
{
string pagenum = context.Request.Params["count"].ToString();
int ipagenum = Convert.ToInt32(pagenum);
fenyeSlect ff = new fenyeSlect();
DataSet ds = ff.GetPageData((ipagenum - 1) * 10 + 1, (ipagenum) * 10);
DataTable dt = ds.Tables[0];
List<News> list = new List<News>();
// string[] list00=new string[dt.Rows.Count];
for (int row = 0; row < dt.Rows.Count; row++)
{
// list00[row] = dt.Rows[row][1].ToString();
list.Add(new News { datetime = dt.Rows[row][1].ToString(), Msg = dt.Rows[row][2].ToString(), ID = dt.Rows[row][0].ToString() });
}
JavaScriptSerializer jss = new JavaScriptSerializer();
string data = jss.Serialize(list);
context.Response.Write(data);
}
//context.Response.Write("Hello World");
}
public bool IsReusable {
get {
return false;
}
}
public class fenyeSlect
{
public SqlConnection getconn()
{
string con = "server=.;uid=sa;pwd=nexel;database=wsxfy;";
SqlConnection conn = new SqlConnection(con);
return conn;
}
/// <summary>
/// 获得条数,有多少条数据
/// </summary>
/// <returns></returns>
public DataSet selectCount()
{
string selectCount = "SELECT COUNT(*) FROM T_Comment";
DataSet ds = new DataSet();
SqlConnection conn = getconn();
conn.Open();
SqlDataAdapter da = new SqlDataAdapter(selectCount, conn);
da.Fill(ds);
return ds;
}
public DataSet GetPageData(int StartRowIndex, int EndRowIndex)
{
// string fenye = "select * from (select ID,Title,Person,[Time],Row_Number() over(order by ID desc) rownum from tb_IndustryNews)t where t.rownum>="+StartRowIndex+" and t.rownum<="+EndRowIndex+"";
StringBuilder sql = new StringBuilder();
sql.Append("select * from ( ");
sql.Append("select ID,PostDate,Msg,Row_Number() over(order by ID desc) Rownum from T_Comment ");
sql.Append(")t ");
sql.Append("where t.Rownum>='" + StartRowIndex + "' and t.Rownum<='" + EndRowIndex + "'");
DataSet ds = new DataSet();
SqlConnection conn = getconn();
conn.Close();
SqlDataAdapter da = new SqlDataAdapter(sql.ToString(), conn);
da.Fill(ds);
return ds;
}
}
public class News
{
public string datetime { get; set; }
public string Msg { get; set; }
public string ID { get; set; }
}
}
学习笔记之AJAX无刷新分页的更多相关文章
- ajax 无刷新分页
//ajax 无刷新分页1.前台要做的 滑动时 当前page+1,通过page ajax请求后台接口获取数据将数据进行拼装;2.后台要做的 做分页接口返回json数据前台判断触发请求条件: var p ...
- thinkphp ajax 无刷新分页效果的实现
思路:先做出传统分页效果,然后重新复制一份Page.class.php类,对它进行修改,把js中的函数传到page类中,把上一页.下一页.首页.尾页.链接页中的url地址改成js控制的函数,模板页面中 ...
- 关于Ajax无刷新分页技术的一些研究 c#
关于Ajax无刷新分页技术的一些研究 c# 小弟新手,求大神有更好的解决方案,指教下~ 以前做项目,用过GridView的刷新分页,也用过EasyUI的封装好的分页技术,最近在老项目的基础上加新功能, ...
- thinkphp下实现ajax无刷新分页
1.前言 作为一名php程序员,我们开发网站主要就是为了客户从客户端进行体验,在这里,thinkphp框架自带的分页类是每次翻页都要刷新一下整个页面,这种翻页的用户体验显然是不太理想的,我们希望每次翻 ...
- ThinkPhp 3.2 ajax无刷新分页(未完全改完,临时凑合着用)
临时更改后的page类(很多地方没修改...因为笔者PHP没学好..)如下: <?phpnamespace Fenye\libs; /** file: page.class.php 完美分 ...
- Ajax无刷新分页
前台代码: <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="AjaxPage ...
- jquery+jquery.pagination+php+ajax 无刷新分页
<!DOCTYPE html> <html ><head><meta http-equiv="Content-Type" content= ...
- SUI分页组件和avalon搞定ajax无刷新分页
<div ms-controller="main"> <h2 class="pagination-centered">{{ title ...
- php+ajax无刷新分页原生ajax实现分页最简单完整实例-完整代码,
展示页面:index.html <html><script> function ajax_show() { // 获取当前页 var page =1; var xhr = ne ...
随机推荐
- 关于function与closure
function 方式 scope function closure expression anonymous function class(this, prototype)
- Steps
uva846:http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_proble ...
- MYSQL用SOURCE命令时导入乱码的问题解决
现在遇到了,但记得上次辉哥说过的方法,在MYSQL命令行里输入: set names utf8; 再执行SOURCE命令,搞定!
- SCALA当的trait
不是特别懂,但感觉和RUBY当中的MIX-IN功能有几分相似,这又扯到了多重继承及JAVA当中的接口虚拟类了.. package com.hengheng.scala class UseTrait { ...
- U盘安装,FTP安装CENTOS--错误信息:Unable to read package metadata.This may be due to a missing repodata directory.
考察repodata下的repomd.xml里的文件和同一目录下的那些文件是不是一一对应的.主要看有没后缀.如果不一致,则要用XML里的文件后缀加上去. 弄了我好多次. http://renzhenx ...
- 【HDOJ】1158 Employment Planning
简单DP. #include <cstdio> #include <cstring> #include <cstdlib> #include <climits ...
- -_-#【Canvas】FPS
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- -_-#【Canvas】转成黑白
function drawInBlackAndWhite() { var imagedata = context.getImageData(0, 0, canvas.width, canvas.hei ...
- 【数学】HDU 5761 Rower Bo
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5761 题目大意: 船在(0,a),船速v1,水速v2沿x轴正向,船头始终指向(0,0),问到达(0, ...
- win8.1 Dism 应用实例
使用win8.1安装镜像制作wimboot启动 制作wim启动映像文件 Dism /Export-Image /WIMBoot/SourceImageFile:z:\sources\install.w ...