我的编程空间,编程开发者的网络收藏夹
学习永远不晚

JQuery中怎么实现一个分页程序

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

JQuery中怎么实现一个分页程序

这篇文章将为大家详细讲解有关JQuery中怎么实现一个分页程序,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

首先Default.aspx页面需要引用的JS文件

Default.aspx页面js代码,如下,每页条数可以自定义,也可以放置配置文件中,queryString函数是根据URL参数名称,获取参数的值

<script type="text/javascript">          var pagesize = 10;          var page = thispage();          $(document).ready(function () {              ajaxList(page);          });           function queryString(pname) {              var query = location.search.substring(1);              var str = "";              params = query.split("&");              if (params.length > 0) {                  for (var n in params) {                      var pairs = params[n].split("=");                      if (pairs[0] == pname) {                          str = pairs[1];                          break;                      }                  }              }              return str;          }           function thispage() {              var r = /^[1-9][0-9]*$/;              if (queryString('page') == '') return 1;              if (r.test(queryString('page')))                  return parseInt(queryString('page'));              else                 return 1;          }           function ajaxList(currentpage) {              if (currentpage != null) page = currentpage;              $.ajax({                  type: "get",//get类型,获取用QueryString方法,post类型,用Form获取传值                  dataType: "json",                  data: "pageIndex=" + currentpage + "&pagesize=" + pagesize + "&clienttt=" + Math.random(),                  url: "Member_Ajax.aspx",                  error: function (XmlHttpRequest, textStatus, errorThrown) { alert(XmlHttpRequest.responseText); },                  success: function (d) {                      switch (d.result) {                          case '-1':                              Alert(d.returnval);                              break;                          case '0':                              Alert(d.returnval);                              break;                          case '1':                              $("#ajaxList").setTemplateElement("tplList", null, { filter_data: true });                              $("#ajaxList").processTemplate(d);                              $("#ajaxPageBar").html(d.pagebar);                              break;                      }                  }              });          }    </script>

Default.aspx页面Form代码如下,页面数据使用JQuery jTemplates绑定数据,非常方便,只需设置JSON格式数据,引用JS文件即可

<textarea id="tplList" style="display: none">             <table class="cooltable" width="300px">             <thead>                 <tr>                     <th align="center" scope="col" style="width:30px;"><input onclick="checkAllLine()" id="checkedAll" name="checkedAll" type="checkbox" title="全部选择/全部不选" /></th>                     <th scope="col" style="width:60px;">ID</th>                     <th width="120px">姓名</th>                     <th scope="col" width="60px">年龄</th>                                      </tr>             </thead>             <tbody>     {#foreach $T.table as record}      <tr>         <td align="center">             <input class="checkbox" name="selectID" type="checkbox" value='{$T.record.MemberNo}' />         </td>         <td align="center">{$T.record.Id}</td>         <td align="left">             {$T.record.Name}          </td>         <td align="left">             {$T.record.Age}          </td>     </tr>     {#/for}  </tbody>             </table>      </textarea>     <div id="ajaxList" style="width:500px;">     </div><br />     <div id="ajaxPageBar" style="width:500px;">     </div>

$T.record.Id 中Id对应的是实体类Id属性

上面Javascript方法中用到Member_Ajax.aspx页面代码如下,注意:这里是将数据已JSON格式输出到页面,配合JQuery数据模板使用,所有Member_Ajax.aspx页面,不应该包含Html标签,其代码格式如下

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Member_Ajax.aspx.cs" Inherits="Nick.Kuang.Web.Member_Ajax" %>

Member_Ajax.aspx cs页面代码

protected void Page_Load(object sender, EventArgs e)          {              Response.Write(GetAll());          }           private string GetAll()          {              List<Student> list = new List<Student>();               for (int i = 0; i < 100; i++)              {                  list.Add(new Student { Id = i, Name = "Name" + i, Age = i });              }                            int pageIndex = GetPage();              int pageSize = StrToInt(QueryString("pagesize"), 10); ;              JavaScriptSerializer javascriptSerializer = new JavaScriptSerializer();               string result = javascriptSerializer.Serialize(list.Skip(pageSize * (pageIndex - 1)).Take(pageSize).ToList());              string response = "{\"result\" :\"1\"," +                  "\"returnval\" :\"操作成功\"," +                  "\"pagebar\" :\"" + PageBar.GetPageBar(3, "js", 2, list.Count, pageSize, pageIndex, "javascript:ajaxList(<#page#>);") + "\"," +                 "\"" + "totalCountStr" + "\":" + 10 + ",\"" + "table" + "\":" + result +                   "}";              return response;          }           private static int GetPage()          {              int page = StrToInt(QueryString("pageIndex"), 0) < 1 ? 1 : StrToInt(QueryString("pageIndex"), 0);              return page;          }           private static int StrToInt(string value, int defaultValue)          {              if (IsNumeric(value))                  return int.Parse(value);              else                  return defaultValue;          }           /// <summary>         /// 获取querystring          /// </summary>         /// <param name="s">参数名</param>         /// <returns>返回值</returns>         private static string QueryString(string s)          {              if (HttpContext.Current.Request.QueryString[s] != null && HttpContext.Current.Request.QueryString[s] != "")              {                  return SafetyQueryS(HttpContext.Current.Request.QueryString[s].ToString());              }              return string.Empty;          }           /// <summary>         /// 将字符串中的一些标签过滤          /// </summary>         /// <param name="theString"></param>         /// <returns></returns>         private static string SafetyQueryS(string theString)          {              string[] aryReg = { "'", ";", "\"", "\r", "\n", "<", ">" };              for (int i = 0; i < aryReg.Length; i++)              {                  theStringtheString = theString.Replace(aryReg[i], string.Empty);              }              return theString;          }           private static bool IsNumeric(string value)          {              System.Text.RegularExpressions.Regex myRegex = new System.Text.RegularExpressions.Regex("^[-]?[1-9]*[0-9]*$");              if (value.Length == 0)              {                  return false;              }              return myRegex.IsMatch(value);          }

使用JavaScriptSerializer中的Serialize方法可以将Object类型数据转换成JSON格式的数据,告别以前拼接成字串的方法

Student实体类代码属性

public class Student      {          public int Id { get; set; }           public string Name { get; set; }           public int Age { get; set; }      }

分页中用到的PageBar类代码,分页调用Default.aspx中ajaxList函数,实现无刷新分页

public class PageBar      {          /// <summary>          /// 完整模式:数字+上下页+首末+总记录信息+指定页码翻转       /// </summary>          /// <param name="stype"></param>          /// <param name="stepNum"></param>          /// <param name="pageRoot"></param>          /// <param name="pageFoot"></param>          /// <param name="countNum"></param>          /// <param name="currentPage"></param>          /// <param name="Http1"></param>          /// <param name="HttpM"></param>          /// <param name="HttpN"></param>          /// <param name="limitPage"></param>          /// <returns></returns>          private static string GetDetailbar(string stype, int stepNum, int pageRoot, int pageFoot, int pageCount, int countNum, int pageSize, int currentPage, string Http1, string HttpM, string HttpN, int limitPage)          {              StringBuilder sb = new StringBuilder();              sb.Append("<div class='p_btns'>");              //sb.Append("<span class='total_count'>共" + countNum.ToString() + "条,当前第" + currentPage.ToString() + "/" + pageCount.ToString() + "页&nbsp;&nbsp;&nbsp;</span>");              sb.Append("<span class='total_count'>共" + countNum.ToString() + "条记录/" + pageCount.ToString() + "页&nbsp;&nbsp;</span>");              if (countNum > pageSize)              {                  if (currentPage != 1)//只要不是***页                      sb.Append("<a target='_self' href='" + GetPageUrl(currentPage - 1, Http1, HttpM, HttpN, limitPage) + "' title='上一页'>&laquo;</a>");                  if (pageRoot > 1)                  {                      sb.Append("<a target='_self' href='" + GetPageUrl(1, Http1, HttpM, HttpN, limitPage) + "'>1..</a>");                  }                  if (stepNum > 0)                  {                      for (int i = pageRoot; i <= pageFoot; i++)                      {                          if (i == currentPage)                              sb.Append("<span class='currentpage'>" + i.ToString() + "</span>");                          else                             sb.Append("<a target='_self' href='" + GetPageUrl(i, Http1, HttpM, HttpN, limitPage) + "'>" + i.ToString() + "</a>");                          if (i == pageCount)                              break;                      }                  }                  if (pageFoot < pageCount)                  {                      sb.Append("<a target='_self' href='" + GetPageUrl(pageCount, Http1, HttpM, HttpN, limitPage) + "'>.." + pageCount + "</a>");                   }                  if (currentPage != pageCount)//只要不是***一页                      sb.Append("<a target='_self' href='" + GetPageUrl(currentPage + 1, Http1, HttpM, HttpN, limitPage) + "' title='下一页'>&raquo;</a>");                  if (stype == "html")                      sb.Append("<span class='jumppage'>转到第 <input type='text' name='custompage' size='2' onkeyup=\"this.value=this.value.replace(/\\D/g,'')\" onafterpaste=\"this.value=this.value.replace(/\\D/g,'')\" onkeydown=\"if(event.keyCode==13) {window.location='" + HttpN + "'.replace('<#page#>',this.value); return false;}\" /> 页</span>");              }              sb.Append("</div>");              return sb.ToString();          }           /// <summary>          /// 分页导航          /// </summary>          /// <param name="mode">支持1=simple,2=normal,3=full</param>          /// <param name="stype">html/js,只有当stype为html且mode为3的时候显示任意页的转向</param>          /// <param name="stepNum">步数,如果步数为i,则每页的数字导航就有2i+1</param>          /// <param name="countNum">记录总数</param>          /// <param name="pageSize">每页记录数</param>          /// <param name="currentPage">当前页码</param>          /// <param name="Http1">第1页的链接地址模板,支持js</param>          /// <param name="HttpM">第M页的链接地址模板,支持js,M不大于limitPage</param>          /// <param name="HttpN">第N页的链接地址模板,支持js,N大于limitPage</param>          /// <param name="limitPage"></param>          /// <returns></returns>          public static string GetPageBar(int mode, string stype, int stepNum, int countNum, int pageSize, int currentPage, string Http1, string HttpM, string HttpN, int limitPage)          {              string pagebar = "";              //if (countNum > pageSize)              //{              int pageCount = countNum % pageSize == 0 ? countNum / pageSize : countNum / pageSize + 1;              currentPage = currentPage > pageCount ? pageCount : currentPage;              currentPage = currentPage < 1 ? 1 : currentPage;              int stepageSize = stepNum * 2;              int pageRoot = 1;              int pageFoot = pageCount;              pageCount = pageCount == 0 ? 1 : pageCount;              if (pageCount - stepageSize < 1)//页数比较少              {                  pageRoot = 1;                  pageFoot = pageCount;              }              else             {                  pageRoot = currentPage - stepNum > 1 ? currentPage - stepNum : 1;                  pageFoot = pageRoot + stepageSize > pageCount ? pageCount : pageRoot + stepageSize;                  pageRoot = pageFoot - stepageSize < pageRoot ? pageFoot - stepageSize : pageRoot;              }                           pagebar = GetDetailbar(stype, stepNum, pageRoot, pageFoot, pageCount, countNum, pageSize, currentPage, Http1, HttpM, HttpN, limitPage);                                 return pagebar;          }           public static string GetPageBar(int mode, string stype, int stepNum, int countNum, int pageSize, int currentPage, string HttpN)          {              return GetPageBar(mode, stype, stepNum, countNum, pageSize, currentPage, HttpN, HttpN, HttpN, 0);          }           public static string GetPageUrl(int chkPage, string Http1, string HttpM, string HttpN, int limitPage)          {              string Http = string.Empty;              if (chkPage == 1)                  Http = Http1;              else                 Http = (chkPage > limitPage || limitPage == 0) ? HttpN : HttpM;              return Http.Replace("<#page#>", chkPage.ToString());          }      }

关于JQuery中怎么实现一个分页程序就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

JQuery中怎么实现一个分页程序

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

PHP中怎么实现一个分页函数

PHP中怎么实现一个分页函数,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。写列表性质的页面,几乎都要写上一段分页的程序。最近小阳终于决心一劳永逸——
2023-06-17

Java中怎么实现一个多线程程序

Java中怎么实现一个多线程程序,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。Java多线程程序设计详细解析一、理解Java多线程Java多线程是这样一种机制,它允许在程序中并
2023-06-17

怎么在Java中实现一个分页遍历功能

怎么在Java中实现一个分页遍历功能?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1. 数据查询模拟首先mock一个分页获取数据的逻辑,直接随机生成数据,并且控制最多返回三页p
2023-06-06

怎么在Java项目中实现一个分页功能

怎么在Java项目中实现一个分页功能?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。分页对象public class PageUtils implements Seriali
2023-05-31

VB.NET中怎么实现一个任务栏程序

今天就跟大家聊聊有关VB.NET中怎么实现一个任务栏程序,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。VB.NET任务栏程序的实现步骤如下:1.启动 .NET 环境, 新建一个 VB
2023-06-17

使用Django怎么实现一个分页功能

这篇文章主要为大家详细介绍了使用Django怎么实现一个分页功能,文中示例代码介绍的非常详细,具有一定的参考价值,发现的小伙伴们可以参考一下:创建项目创建APP,添加APP这些就不在多说我们这次重点来看到视图函数下面是路由设置视图函数继承T
2023-06-06

怎么使用JQuery实现分页插件

要使用jQuery实现分页插件,可以按照以下步骤进行操作:1. 首先,引入jQuery库文件和自定义的分页插件文件到HTML页面中。```html```2. 创建一个HTML元素,用于显示分页导航条。```html
2023-08-15

Java中怎么实现一个计算器小程序

Java中怎么实现一个计算器小程序,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。代码如下:package tst.jframe; import java.awt
2023-06-20

C#中怎么实现一个屏幕保护程序

C#中怎么实现一个屏幕保护程序,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。C#屏幕保护程序不仅可以延长显示器的使用寿命,还可以保护私人信息。本文向大家介绍一个
2023-06-18

PHP中怎么实现一个静态页面

这篇文章将为大家详细讲解有关PHP中怎么实现一个静态页面,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。一,PHP脚本与动态页面。PHP脚本是一种服务器端脚本程序,可通过嵌入等方法与HTML文
2023-06-17

使用Ajax怎么实现一个无刷新分页

本篇文章为大家展示了使用Ajax怎么实现一个无刷新分页,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。
2023-06-08

小程序分享页面图片怎么实现

本篇内容介绍了“小程序分享页面图片怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!    开发微信小程序的时候,经常要遇到如上图这样的
2023-06-26

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录