原创:仿Baidu,Google查询分页技术JAVA实现

在上一节中我们简单观察与分析了仿baidu,google的查询分页技术,有很多学生纷纷的给我来了邮件,期待着使用Java技术的实现.在这里很感谢大家对我的关注,我会一如既往的在此平台之上发布自己的授课中一些知识点的总结.下将仿baidu,google查询分页技术的实现方式一种分享给大家,如有问题请及时发送邮件.希望同学们在这新的学期中有更大的收获。

在这里我简单说说我的实现思路,我将整个分页的技术全部封装在了一个Pagination的JavaBean中.具体代码如下:

Java代码 复制代码
  1. packagecn.csdn.util;
  2. importjava.util.List;
  3. /**
  4. *
  5. *@authorredarmy_chen
  6. *
  7. *@param<T>
  8. */
  9. publicclassPagination<T>{
  10. //分页信息
  11. privateintnowpage;//当前页
  12. privateintcountrecord;//总记录
  13. privateintcountpage;//总页数
  14. publicstaticfinalintPAGESIZE=5;//每页显示的记录数
  15. privateintstartpage;//页面中的起始页
  16. privateintendpage;//页面中的结束页
  17. privatefinalintSHOWPAGE=6;//页面中显示的总页数baidu,google显示的总页数是20
  18. //在测试我们才用6来测试
  19. privateList<T>allentities;
  20. privateStringurl;
  21. /**根据当前页及总记录数来构造分页对象*/
  22. publicPagination(intnowpage,intcountrecord){
  23. this.nowpage=nowpage;
  24. this.countrecord=countrecord;
  25. /**计算总页数*/
  26. this.countpage=this.countrecord%this.PAGESIZE==0?this.countrecord
  27. /this.PAGESIZE
  28. :this.countrecord/this.PAGESIZE+1;
  29. /**计算startpage与endpage的值*/
  30. /**总页数数是否小于4*/
  31. if(this.countpage<(this.SHOWPAGE/2+1)){
  32. this.startpage=1;//页面中起始页就是1
  33. this.endpage=this.countpage;//页面中的最终页就是总页数
  34. }else{
  35. /**else中是总页数大于4的情况*/
  36. /**首先当前页的值是否小于等于4*/
  37. if(this.nowpage<=(this.SHOWPAGE/2+1)){
  38. this.startpage=1;
  39. this.endpage=this.nowpage+2;
  40. /**判断页面的最终页是否大于总页数*/
  41. if(this.endpage>=this.countpage){
  42. this.endpage=this.countpage;
  43. }
  44. }else{
  45. this.startpage=this.nowpage-3;
  46. this.endpage=this.nowpage+2;
  47. if(this.endpage>=this.countpage){
  48. this.endpage=this.countpage;
  49. if(this.countpage<this.SHOWPAGE){
  50. this.startpage=1;
  51. }else{
  52. this.startpage=this.endpage-5;
  53. }
  54. }
  55. }
  56. }
  57. }
  58. publicintgetNowpage(){
  59. returnnowpage;
  60. }
  61. publicvoidsetNowpage(intnowpage){
  62. this.nowpage=nowpage;
  63. }
  64. publicintgetCountrecord(){
  65. returncountrecord;
  66. }
  67. publicvoidsetCountrecord(intcountrecord){
  68. this.countrecord=countrecord;
  69. }
  70. publicintgetCountpage(){
  71. returncountpage;
  72. }
  73. publicvoidsetCountpage(intcountpage){
  74. this.countpage=countpage;
  75. }
  76. publicintgetStartpage(){
  77. returnstartpage;
  78. }
  79. publicvoidsetStartpage(intstartpage){
  80. this.startpage=startpage;
  81. }
  82. publicintgetEndpage(){
  83. returnendpage;
  84. }
  85. publicvoidsetEndpage(intendpage){
  86. this.endpage=endpage;
  87. }
  88. publicList<T>getAllentities(){
  89. returnallentities;
  90. }
  91. publicvoidsetAllentities(List<T>allentities){
  92. this.allentities=allentities;
  93. }
  94. publicStringgetUrl(){
  95. returnurl;
  96. }
  97. publicvoidsetUrl(Stringurl){
  98. this.url=url;
  99. }
  100. }
package cn.csdn.util; import java.util.List; /** * * @author redarmy_chen * * @param <T> */ public class Pagination<T> { // 分页信息 private int nowpage;// 当前页 private int countrecord;// 总记录 private int countpage;// 总页数 public static final int PAGESIZE = 5;// 每页显示的记录数 private int startpage;// 页面中的起始页 private int endpage;// 页面中的结束页 private final int SHOWPAGE = 6;// 页面中显示的总页数 baidu,google显示的总页数是20 // 在测试我们才用6来测试 private List<T> allentities; private String url; /** 根据当前页及总记录数来构造分页对象 */ public Pagination(int nowpage, int countrecord) { this.nowpage = nowpage; this.countrecord = countrecord; /** 计算总页数 */ this.countpage = this.countrecord % this.PAGESIZE == 0 ? this.countrecord / this.PAGESIZE : this.countrecord / this.PAGESIZE + 1; /** 计算startpage与endpage的值 */ /** 总页数数是否小于4 */ if (this.countpage < (this.SHOWPAGE / 2 + 1)) { this.startpage = 1; // 页面中起始页就是1 this.endpage = this.countpage;// 页面中的最终页就是总页数 } else { /** else中是总页数大于4的情况 */ /** 首先当前页的值是否小于等于4 */ if (this.nowpage <= (this.SHOWPAGE / 2 + 1)) { this.startpage = 1; this.endpage = this.nowpage + 2; /** 判断页面的最终页是否大于总页数 */ if (this.endpage >= this.countpage) { this.endpage = this.countpage; } } else { this.startpage = this.nowpage - 3; this.endpage = this.nowpage + 2; if (this.endpage >= this.countpage) { this.endpage = this.countpage; if (this.countpage < this.SHOWPAGE) { this.startpage = 1; } else { this.startpage = this.endpage - 5; } } } } } public int getNowpage() { return nowpage; } public void setNowpage(int nowpage) { this.nowpage = nowpage; } public int getCountrecord() { return countrecord; } public void setCountrecord(int countrecord) { this.countrecord = countrecord; } public int getCountpage() { return countpage; } public void setCountpage(int countpage) { this.countpage = countpage; } public int getStartpage() { return startpage; } public void setStartpage(int startpage) { this.startpage = startpage; } public int getEndpage() { return endpage; } public void setEndpage(int endpage) { this.endpage = endpage; } public List<T> getAllentities() { return allentities; } public void setAllentities(List<T> allentities) { this.allentities = allentities; } public String getUrl() { return url; } public void setUrl(String url) { this.url = url; } }


以上内容归redarmy_chen原创,版权归redarmy_chen所有不得随意转载 如有问题请发送邮件到redarmy_chen@qq.com
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值