angularjs ajax分页,AngularJS 前台分页实现的示例代码

考评员查询,因为整体的数据量比较小,所以我们可以将分页放到前台进行处理。

其实分页的原理也很简单,我们根据分页选择的页码数和每页数据条数决定当前显示的是数组中的第多少项到多少项,然后再构造分页的参数传入已有的分页指令。

// 初始化分页参数

$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,则为尾页。

043db1b172adab5cd868a3c655e04c6b.png

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值