asp.net中利用Jquery+Ajax+Json实现无刷新分页(二)
- <%@ Page Language="C#" AutoEventWireup="true" CodeFile="PageTest.aspx.cs" Inherits="renmai_PageTest" %>
- <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
- <html xmlns="http://www.w3.org/1999/xhtml">
- <head runat="server">
- <title>Jquery+Ajax分页测试</title>
- <script src="../js/jquery-1.11.1.min.js" type="text/javascript"></script>
- <script type="text/javascript">
- $(function () {
- InitPage(1, 10);
- $(".nextPage").click(function () {
- InitPage($("#nextpage").val(), 10);
- });
- });
- //请求数据
- function InitPage(pageIndex, pageSize) {
- $.ajax({
- type: "POST",
- dataType: "json",
- url: '/Handler/Handler1.ashx',
- data: "type=show&random=" + Math.random() + "&pageIndex=" + pageIndex + "&pageSize=" + pageSize,
- error: function () { alert('error data'); }, //错误执行方法
- success: function (data) {
- var json = data; //数组
- var recordCount = json.table2[0].recordcount;
- var pageCount = json.table2[0].pagecount;
- var html = "";
- $.each(json.table1, function (index, item) {
- //循环获取数据
- var id = item.Id;
- var name = item.Name;
- var sex = item.Sex;
- html += "<tr><td>" + id + "</td><td>" + name + "</td><td>" + sex + "</td></tr>";
- });
- $("#Result").append(html);
- if (pageIndex >= parseInt(pageCount)) {
- $(".nextPage").hide();
- }
- else {
- $("#nextpage").val(parseInt(pageIndex) + 1)
- }
- }
- });
- };
- </script>
- </head>
- <body>
- <form id="form1" runat="server">
- <div>
- <input type="hidden" id="nextpage" value="1" />
- <table id="Result" cellspacing="0" cellpadding="0">
- <tr>
- <th style="width:50px;">
- 编号
- </th>
- <th style="width:100px;">
- 姓名
- </th>
- <th style="width:50px;">
- 性别
- </th>
- </tr>
- </table>
- <a href="javascript:void(0)" class="nextPage">下一页</a>
- </div>
- </form>
- </body>
- </html>
- <%@ WebHandler Language="C#" Class="Handler1" %>
- using System;
- using System.Web;
- using System.Data;
- using Newtonsoft.Json;
- public class Handler1 : IHttpHandler {
- /* Handler/Handler1.ashx */
- protected static int RecordCount = 0;
- protected static DataTable dt = CreateDT();
- public void ProcessRequest (HttpContext context) {
- string type=context.Request["type"];
- int pageIndex = MSCL.ConvertHelper.ObjectToInt(context.Request["pageIndex"]);
- int pageSize = MSCL.ConvertHelper.ObjectToInt(context.Request["pageSize"]);
- switch (type)
- {
- case "show":
- #region 分页配置
- if (pageIndex == 0) { pageIndex = 1; }
- #endregion
- DataSet ds = new DataSet();
- DataTable dtData = GetPagedTable(dt, pageIndex, pageSize);
- dtData.TableName = "table1";
- DataTable dtCount = new DataTable();
- dtCount.TableName = "table2";
- dtCount.Columns.Add("recordcount");
- dtCount.Rows.Add(dt.Rows.Count);
- ds.Tables.Add(dtData);
- ds.Tables.Add(dtCount);
- string json = JsonConvert.SerializeObject(ds, Formatting.Indented);
- context.Response.Write(json);
- break;
- default :
- break;
- }
- context.Response.End();
- }
- #region 模拟数据
- private static DataTable CreateDT()
- {
- DataTable dt = new DataTable();
- dt.Columns.Add(new DataColumn("Id", typeof(int)) { DefaultValue = 0 });
- dt.Columns.Add(new DataColumn("Name", typeof(string)) { DefaultValue = "1" });
- dt.Columns.Add(new DataColumn("Sex", typeof(string)) { DefaultValue = "男" });
- for (int i = 1; i <= 58; i++)
- {
- dt.Rows.Add(i, "张三" + i.ToString().PadLeft(4, '0'));
- }
- RecordCount = dt.Rows.Count;
- return dt;
- }
- #endregion
- /// <summary>
- /// 对DataTable进行分页,起始页为1
- /// </summary>
- /// <param name="dt"></param>
- /// <param name="PageIndex"></param>
- /// <param name="PageSize"></param>
- /// <returns></returns>
- public static DataTable GetPagedTable(DataTable dt, int PageIndex, int PageSize)
- {
- if (PageIndex == 0)
- return dt;
- DataTable newdt = dt.Copy();
- newdt.Clear();
- int rowbegin = (PageIndex - 1) * PageSize;
- int rowend = PageIndex * PageSize;
- if (rowbegin >= dt.Rows.Count)
- return newdt;
- if (rowend > dt.Rows.Count)
- rowend = dt.Rows.Count;
- for (int i = rowbegin; i <= rowend - 1; i++)
- {
- DataRow newdr = newdt.NewRow();
- DataRow dr = dt.Rows[i];
- foreach (DataColumn column in dt.Columns)
- {
- newdr[column.ColumnName] = dr[column.ColumnName];
- }
- newdt.Rows.Add(newdr);
- }
- return newdt;
- }
- /// <summary>
- /// 获取总页数
- /// </summary>
- /// <param name="sumCount">结果集数量</param>
- /// <param name="pageSize">页面数量</param>
- /// <returns></returns>
- public static int getPageCount(int sumCount, int pageSize)
- {
- int page = sumCount / pageSize;
- if (sumCount % pageSize > 0)
- {
- page = page + 1;
- }
- return page;
- }
- public bool IsReusable {
- get {
- return false;
- }
- }
- }
asp.net中利用Jquery+Ajax+Json实现无刷新分页(二)的更多相关文章
- jquery ajax php+mysql 无刷新分页 详细实例
最近在接触jquery和ajax,当前项目也会用到分页,为了用户体验更好一些,就准备用无刷新分页,这个demo很适合新手学习查看,写的比较清晰,话不多说,直接上代码吧. 首先是html页面,index ...
- ajax分页2:jquery.pagination +JSON 动态无刷新分页
静态页面: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w ...
- jquery.pagination +JSON 动态无刷新分页
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="SqlPage.aspx.cs& ...
- ASP.NET Ajax简单的无刷新分页
最近练习了一些AJAX无刷新分页,写得比较简单,性能不知道怎么样,求大神指点,如有更好的分页提供,欢迎交流! 发话不多说了,直接上代码! 首先从网上下了一个JS分页,感觉挺好用的 (function( ...
- 本篇文章主要是对jquery+ajax+C#实现无刷新操作数据库数据的简单实例进行了介绍,需要的朋友可以过来参考下,希望对大家有所帮助
我们知道同步执行和异步执行的区别,为了更好的提高用户的体验,我们都会采用异步方式去处理一些问题,毕竟单线程的同步可能回造成卡死等现象,很不友好,所以可以使用ajax来完成用户的体验,现在我们就来说说如 ...
- TP2.0或3.1 或者 3.2 下使用ajax+php做无刷新分页(转+自创)
1.前言 作为一名php程序员,我们开发网站主要就是为了客户从客户端进行体验,在这里,thinkphp框架自带的分页类是每次翻页都要刷新一下整个页面,这种翻页的用户体验显然是不太理想的,我们希望每次翻 ...
- Bootstrap Paginator分页插件+ajax 实现动态无刷新分页
之前做分页想过做淘宝的那个,但是因为是后台要求不高,就Bootstrap Paginator插件感觉还蛮容易上手,所以就选了它. Bootstrap Paginator分页插件下载地址: Downlo ...
- asp.net 中使用JQuery Ajax 上传文件
首先创建一个网页,网页中添加如下代码. <h3>Upload File using Jquery AJAX in Asp.net</h3> <table> < ...
- jQuery+AJAX实现网页无刷新上传
新年礼,提供简单.易套用的 jQuery AJAX上传示例及代码下载.后台对文件的上传及检查,以 C#/.NET Handler 处理 (可视需要改写成 Java 或 PHP). 有时做一个网站项目 ...
随机推荐
- linux系统下C语言调用lapack ,blas库
在利用C语言编程,经常调用其他的软件包,其中lapack,blas库是最常用的两个库,这里讲下在linux系统下,C语言编程如何调用这两个库: 1.首先讲下blas库的调用,这里以两个向量内积函数为例 ...
- C语言中指针*p[N], (*P)[N],及**p的区别
在C语言编程中指针经常困扰着我们,但是若能灵活运用指针的话,将会使得我们编程变得更加轻松与高效.这里讲下*p[N], (*P)[N],及**p的区别,这也是之前经常困扰我的地方. 这三者的定义分别为: ...
- ZXing生成条形码、二维码、带logo二维码
采用的是开源的ZXing,Maven配置如下,jar包下载地址,自己选择版本下载,顺便推荐下Maven Repository <!-- https://mvnrepository.com/art ...
- 32位汇编第三讲,RadAsm,IDE的配置和使用,以及汇编代码注入方式
32位汇编第三讲,RadAsm,IDE的配置和使用,以及汇编代码注入方式 一丶RadAsm的配置和使用 用了怎么长时间的命令行方式,我们发现了几个问题 1.没有代码提醒功能 2.编写代码很慢,记不住各 ...
- 32位汇编第四讲,干货分享,汇编注入的实现,以及快速定位调用API的数量(OD查看)
32位汇编第四讲,干货分享,汇编注入的实现,以及快速定位调用API的数量(OD查看) 昨天,大家可能都看了代码了,不知道昨天有没有在汇编代码的基础上,实现注入计算器. 如果没有,今天则会讲解,不过建议 ...
- JUnit之TestCase和TestSuite详解
首先介绍下TestCase以及TestSuite. TestCase:字面意思,测试用例.为一个或多个方法提供测试方法.一般是一个test TestSuite:测试集合,即一组测试.一个t ...
- YYHS-怎样更有力气
题目描述 OI大师抖儿在夺得银牌之后,顺利保送pku.这一天,抖儿问长者:"我虽然已经保送了,但我的志向是为国家健康工作五十年.请问我应该怎样变得更有力气?" 长者回答:&quo ...
- 【2017集美大学1412软工实践_助教博客】团队作业9——测试与发布(Beta版本)
题目 团队作业9--测试与发布(Beta版本)(http://www.cnblogs.com/happyzm/p/6917253.html) 团队作业9-1 测试与发布成绩 分值 1 0.5 0.5 ...
- java--利用exe4j生成.exe的可执行文件
工具:eclipse,exe4j,jre,这三个都可以直接在官方网站下载,下面所用到的都是最新版的. 前期准备:用eclipse编好需要生成.exe文件的project,另外exe4j需要一个注册码, ...
- 201521123067 《Java程序设计》第6周学习总结
1. 本周学习总结 1.1 面向对象学习暂告一段落,请使用思维导图,以封装.继承.多态为核心概念画一张思维导图,对面向对象思想进行一个总结. 2. 书面作业 Q1:clone方法 1.1 Object ...