page.ejs 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. <style>
  2. ul.pagination {
  3. text-align: center!important;
  4. justify-content: center!important;
  5. }
  6. </style>
  7. <nav aria-label="Page navigation example">
  8. <ul class="pagination pagination-sm">
  9. </ul>
  10. </nav>
  11. <script type="text/javascript" src="/public/js/bootstrap/bootstrap-paginator.js"></script>
  12. <script type="text/javascript">
  13. let options = {
  14. bootstrapMajorVersion: 4,
  15. currentPage: "<%= pageInfo.page %>",
  16. totalPages: "<%= pageInfo.total %>",
  17. numberOfPages: 5,
  18. size: "small",
  19. itemContainerClass: function(type, page, current) {
  20. let className = 'page-item';
  21. this.currentPage = parseInt(this.currentPage);
  22. this.totalPages = parseInt(this.totalPages);
  23. switch (type) {
  24. case "first":
  25. className = this.currentPage === 1 ? className + ' disabled' : className;
  26. break;
  27. case "prev":
  28. className = this.currentPage === 1 ? className + ' disabled' : className;
  29. break;
  30. case "next":
  31. className = this.currentPage === this.totalPages ? className + ' disabled' : className;
  32. break;
  33. case "last":
  34. className = this.currentPage === this.totalPages ? className + ' disabled' : className;
  35. break;
  36. case "page":
  37. className = page === this.currentPage ? className + ' active' : className;
  38. break;
  39. }
  40. return className;
  41. },
  42. itemContentClass: function(type, page, current) {
  43. return 'page-link';
  44. },
  45. itemTexts: function(type, page, current) {
  46. switch (type) {
  47. case "first":
  48. return '<i class="fa fa-caret-left"></i>';
  49. case "prev":
  50. return '<i class="fa fa-angle-left"></i>';
  51. case "next":
  52. return '<i class="fa fa-angle-right"></i>';
  53. case "last":
  54. return '<i class="fa fa-caret-right"></i>';
  55. case "page":
  56. return page;
  57. case "more":
  58. return '...';
  59. }
  60. },
  61. shouldShowPage: function (type, page, current) {
  62. let result = true;
  63. switch (type) {
  64. case "first":
  65. break;
  66. case "prev":
  67. break;
  68. case "next":
  69. break;
  70. case "last":
  71. break;
  72. case "page":
  73. break;
  74. case "more":
  75. result = (page !== this.totalPages);
  76. break;
  77. }
  78. return result;
  79. },
  80. pageUrl: function(type, page, current){
  81. let queryData = JSON.parse('<%- pageInfo.queryData %>');
  82. // 如果没有附带查询条件则直接返回
  83. if (Object.keys(queryData).length <= 0) {
  84. return "?page=" + page;
  85. }
  86. // 有其它数据则重新赋值page,然后组合字符串
  87. queryData.page = page;
  88. let queryArray = [];
  89. for(let tmp in queryData) {
  90. let tempString = tmp + '=' + queryData[tmp];
  91. queryArray.push(tempString);
  92. }
  93. let firstQuery = queryArray.shift();
  94. let queryString = queryArray.join('&');
  95. return queryString === '' ? '?' + firstQuery : '?' + firstQuery + '&' + queryString;
  96. }
  97. };
  98. const pageSizeSelect = <%- pageInfo.pageSizeSelect ? parseInt(pageInfo.pageSizeSelect) : 0 %>;
  99. if (options.totalPages > 1 || pageSizeSelect) {
  100. $(".pagination").bootstrapPaginator(options);
  101. setSelectPageSize(pageSizeSelect);
  102. } else {
  103. $(".pagination").hide();
  104. }
  105. function setSelectPageSize(psSelect) {
  106. if (psSelect === 1) {
  107. let queryData = JSON.parse('<%- pageInfo.queryData %>');
  108. // 有其它数据则重新赋值page,然后组合字符串
  109. delete queryData.page;
  110. delete queryData.pageSize;
  111. let queryArray = [];
  112. for(let tmp in queryData) {
  113. let tempString = tmp + '=' + queryData[tmp];
  114. queryArray.push(tempString);
  115. }
  116. let firstQuery = queryArray.shift();
  117. let queryString = queryArray.join('&');
  118. queryString = firstQuery ? (queryString === '' ? '?' + firstQuery : '?' + firstQuery + '&' + queryString) : '';
  119. const pshtml = '<li class="page-item disabled">\n' +
  120. ' <span class="page-link" >共' + <%- pageInfo.total_num %> + '条</span>\n' +
  121. ' </li>\n' +
  122. ' <li class="page-item">\n' +
  123. ' <span class="page-link" >\n' +
  124. ' <div class="btn-group">\n' +
  125. ' <a type="button" class="text-primary dropdown-toggle" data-toggle="dropdown" id="zhankai" >每页' + <%- pageInfo.pageSize %> + '条</a>\n' +
  126. ' <div class="dropdown-menu" id="zhankaiSelect" aria-labelledby="zhankai" style="">\n' +
  127. ' <a class="dropdown-item" data-size="15" href="'+ (queryString === '' ? '?pageSize=15' : queryString + '&pageSize=15') +'">每页15条</a>\n' +
  128. ' <a class="dropdown-item" data-size="30" href="'+ (queryString === '' ? '?pageSize=30' : queryString + '&pageSize=30') +'">每页30条</a>\n' +
  129. ' <a class="dropdown-item" data-size="50" href="'+ (queryString === '' ? '?pageSize=50' : queryString + '&pageSize=50') +'">每页50条</a>\n' +
  130. ' <a class="dropdown-item" data-size="100" href="'+ (queryString === '' ? '?pageSize=100' : queryString + '&pageSize=100') +'">每页100条</a>\n' +
  131. ' </div>\n' +
  132. ' </div>\n' +
  133. ' </span>\n' +
  134. ' </li>';
  135. $('.pagination').prepend(pshtml);
  136. }
  137. }
  138. $('#zhankaiSelect a').on('click', function () {
  139. setLocalCache('account-pageSize', $(this).data('size'));
  140. })
  141. </script>