时间:2021-05-28
考评员查询,因为整体的数据量比较小,所以我们可以将分页放到前台进行处理。
其实分页的原理也很简单,我们根据分页选择的页码数和每页数据条数决定当前显示的是数组中的第多少项到多少项,然后再构造分页的参数传入已有的分页指令。
// 初始化分页参数$scope.pageParams = { size: $stateParams.size, // 每页数据条数 page: $stateParams.page, // 页码数 last: undefined, // 是否首页 first: undefined, // 是否尾页 totalPages: undefined, // 总页数 totalElements: undefined, // 总数据条数 numberOfElements: undefined // 当前页有几条数据};这是我们的分页指令要的数据,所以我们就是两个任务,第一,截取当前页应该显示的数据,第二生成参数传给分页指令。
这是最后实现的CommonService中的公共方法。
/** * 重新生成分页参数与分页数据 * @param {每页数据条数} size * @param {页码数} page * @param {全部数据} data * @param {Function} callback * callback (pageParams, currentPageData) * pageParams: 分页的标准 * currentPageData: 当前页的数据 */self.reloadPageParamsAndData = function(size, page, data, callback) { // 校验传入的参数 if (typeof size === 'undefined') { throw '未接收到每页数据条数信息'; } if (typeof page === 'undefined') { throw '未接收到分页信息'; } if (typeof data === 'undefined') { throw '未接收到数据信息'; } // 计算总页数和总数据条数 var totalPages = Math.ceil(data.length / size); var totalElements = data.length; // 计算当前页是否为首页 是否为尾页 var first = page === 0 ? true : false; var last = page === totalPages - 1 ? true : false; // 根据分页参数计算当前页应该显示的数据 slice数组元素分割 var currentPageData = data.slice(0 + page * size, size + page * size); // 获取当前页总共有多少条数据 var numberOfElements = currentPageData.length; // 重新生成分页参数 var pageParams = { size: size, // 每页数据条数 page: page, // 页码数 last: last, // 是否首页 first: first, // 是否尾页 totalPages: totalPages, // 总页数 totalElements: totalElements, // 总数据条数 numberOfElements: numberOfElements // 当前页有几条数据 }; // 回调 if (callback) { callback(pageParams, currentPageData); }};获取当前页数据
获取当前页的数据,我们需要知道每页数据条数,页码数即可对数据进行分割。
var currentPageData = data.slice(0 + page * size, size + page * size);对数据进行分割,数据应该是从0到size,加上page * size就是之前的页数中的数据量。
构建分页参数
// 计算总页数和总数据条数var totalPages = Math.ceil(data.length / size);var totalElements = data.length;// 计算当前页是否为首页 是否为尾页var first = page === 0 ? true : false;var last = page === totalPages - 1 ? true : false;// 获取当前页总共有多少条数据var numberOfElements = currentPageData.length;数据总数除以每页数据条数向上取整得到总页数。
如果页数为0,则为首页;如果页数为总页数减1,则为尾页。
复制代码 代码如下:<yunzhi-page reload="reloadByPage" total-pages="pageParams.totalPages" total-elements="pageParams.totalElements" first="pageParams.first" last="pageParams.last" number="pageParams.page" size="pageParams.size" number-of-elements="pageParams.numberOfElements"></yunzhi-page>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
angularjs实现分页查询功能的实例代码,具体代码如下所示://首页导入//routerApp中注入'tm.pagination'//html页面上//co
本文实例为大家分享了jQuerypagination分页示例的具体代码,供大家参考,具体内容如下前台html通知公告列表.page{width:95%;heig
本文展示了AngularJS框架实现的helloworld代码示例.如下是一些你在看HelloWorld示例和接下来的代码示例时需要重点关注的方面.ng-app
前言:之前写个一个jQuery的分页显示插件,存在许多的bug,现在由于业务需要,学习的一点AngularJS,重新用angularjs实现了这个分页插件实现效
PHP技巧实例:Smarty+adodb分页示例 利用Smarty+adodb分页示例,下面给出的是分页部份的代码。 分页文件:page.lbi当前页/