前言

分页组件比较常见,但是用avalon实现的见的不多,这个分页组件,可以适配2种分页方式,

第一种是每次点击下一页,就请求一次后台,并返回当页数据和总条数,我称之为假分页;

第二种是一次性把所有数据取出,每次点击分页,都是在一个数组中截取数据,而不请求后台,我称之为真分页;

在这个组件中,假分页和真分页在使用上,只是在VM中增加一个pageData属性(用于存放每页的数据)即可。

源码请参照:http://runjs.cn/code/xfqlscmq

HTML部分

<div ms-controller="mySingerCtrl">
<div class="wgzd_cnMain01cn01">
<div class="zhuboList">
<div class="zhuboList01" ms-repeat="pageData">
<a target="_blank" class="zhuboLIst01_pic" href="javascript:;">
<img ms-attr-src="el.pic">
</a>
<div class="zhuboList01R"><a target="_blank">{{decodeURIComponent(el.name)}}</a></div>
</div>
</div>
</div>
<div class="fanye" ms-if="totalPage > 1">
<a href="javascript:;" ms-on-click="goPage(1)"><span class="fanye01"></span></a>
<a href="javascript:;" ms-on-click="goPage(pageNo -1 < 1 ? 1 : pageNo -1)"><span class="fanye02"></span></a>
<a href="javascript:;" ms-on-click="goPage(el)" ms-repeat="totalPageArr" ms-attr-class="el == pageNo ? 'fanyeon' : ''">{{ el }}</a>
<a href="javascript:;" ms-on-click="goPage(pageNo + 1 >= totalPage ? totalPage : pageNo +1)"><span class="fanye03"></span></a>
<a href="javascript:;" ms-on-click="goPage(totalPage)"><span class="fanye04"></span></a>
</div>
</div>

VM部分

var mySingerVM = avalon.define({
$id: "mySingerCtrl", //- id
pageData: [], //- 分页数据,用于展示,每页18条
data: [], //- 数据
pageNo: 1, //- 页码
pageSize: 18, //- 每页多少条记录
totalPage: 1, //- 总页数
totalPageArr: [], //- 总页数数组,用于循环页数
goPage: function(pageNo) {
mySingerVM.pageNo = pageNo;
}
});

初始化部分

//- 获取数据主播数据
function init() {
$.getJSON("http://zhiboserver.kuwo.cn/proxy.p?src=MUSIC_WEB&cmd=gethall&type=1&callback=?", function(json) {
mySingerVM.data = json.roomlist;
});
} avalon.ready(function() {
init();
page.init(mySingerVM);
});

Page组件部分

//- 分页功能分为两种,
//- 第一种: 一次全部取出, 假分页
//- 第二种: 每次点击都请求一页数据, 真分页
//- 这个分页方法, 对两种分页都有效果, 假分页需要有一个data对象, 存放全部数据
var page = {
init: function(pageVM) {
var _this = this;
// _this.initPage(pageVM);
pageVM.$watch("pageNo", function() { //- 监听页码变化,点击分页时, 重新初始化分页
_this.initPage(pageVM);
});
//- 监听数据长度,主要是解决初始时, 数据为空, jax请求时, 数据存在之后, 初始化分页
if (pageVM.data) { //- 假分页的方式
pageVM.$watch("data.length", function() {
_this.initPage(pageVM);
});
} else { //- 真分页的方式
pageVM.$watch("pageData.length", function() {
_this.initPage(pageVM);
});
}
},
initPage: function(pageVM) { //- 初始化分页
pageVM.totalPageArr = [];
var _pageNo = pageVM.pageNo;
var _pageSize = pageVM.pageSize;
var totalCnt = 1;
if (pageVM.data) { //- 有data对象, 判定为假分页方式
pageVM.pageData = [];
totalCnt = pageVM.data.size();
var cnt = _pageNo * _pageSize < totalCnt ? _pageNo * _pageSize : totalCnt; //- 防止超出总数
for (var i = (_pageNo - 1) * _pageSize; i < cnt; i++) {
pageVM.pageData.push(pageVM.data[i]);
}
} else {
totalCnt = pageVM.totalCnt;
}
pageVM.totalPage = totalCnt % _pageSize == 0 ? parseInt(totalCnt / _pageSize) : parseInt(totalCnt / _pageSize) + 1;
for (var i = 0; i < pageVM.totalPage; i++) { //- 填充,用于分页循环,因为Avalon不支持数字循环,所以必须把数据转成数组
pageVM.totalPageArr.push(i + 1);
} var _arr = pageVM.totalPageArr; //- 处理页数过多时的问题
if (_arr.size() > 5) {
if (_pageNo - 2 > 0 && _arr.size() - _pageNo > 2) { //- 如果页码在中间
_arr.splice(0, (_pageNo - 3)); //- 先把前面的截取
var length = _arr[_arr.size() - 1] - (_pageNo + 2);
_arr.splice(5, length); //- 再截取后面的
} else if (_pageNo - 2 <= 0) { //- 页码在左边时
var length = _arr[_arr.size() - 1] - 5;
_arr.splice(5, length); //- 再截取后面的
} else if (_arr.size() - _pageNo <= 2) { //- 页码在右边时
var length = _arr[_arr.size() - 1] - 5;
_arr.splice(0, length); //- 再截取后面的
}
}
}
};

avalon实现分页组件的更多相关文章

  1. 一步步编写avalon组件02:分页组件

    本章节,我们做分页组件,这是一个非常常用的组件.grid, listview都离不开它.因此其各种形态也有. 本章节教授的是一个比较纯正的形态,bootstrap风格的那种分页栏. 我们建立一个ms- ...

  2. 基于avalon1.4.x ----分页组件编写

    avalon分页组件 (1.4.x版本) 随着avalon2的推出,avalon1的官网已经不再维护了,现在似乎是找不到avalon 1.4版本的官方文档了,所以本文章所有的内容均不保证正确性,只能保 ...

  3. 基于Vue.js的表格分页组件

    有一段时间没更新文章了,主要是因为自己一直在忙着学习新的东西而忘记分享了,实在惭愧. 这不,大半夜发文更一篇文章,分享一个自己编写的一个Vue的小组件,名叫BootPage. 不了解Vue.js的童鞋 ...

  4. angular-ui分页组件

    http://angular-ui.github.io/bootstrap/#/pagination 分页组件只提供生成分页按钮,数据的显示需要使用ng-repeat, 注意设置 items-per- ...

  5. asp.net mvc4+mysql做一个简单分页组件(部分视图)

    在开始做mysql分页功能组件前,便设定的是要有一定可复用性.先在项目里Views文件夹下右键新建名为_PaginationComponent.cshtml,这里html及css我采用的bootstr ...

  6. ReactJS实现的通用分页组件

    大家多少都自己写过各种版本的分页工具条吧,像纯服务版的,纯jsWeb板的,Angular版的,因为这个基础得不能再基础的功能太多地方都会用到,下面我给出以个用ReactJS实现的版本,首先上图看下效果 ...

  7. 基于vue2.0的分页组件开发

    今天安排的任务是写基于vue2.0的分页组件,好吧,我一开始是觉得超级简单的,但是越写越写不出来,写的最后乱七八糟的都不知道下句该写什么了,所以重新捋了思路,小结一下- 首先写组件需要考虑: 要从父组 ...

  8. 基于Vue封装分页组件

    使用Vue做双向绑定的时候,可能经常会用到分页功能 接下来我们来封装一个分页组件 先定义样式文件 pagination.css ul, li { margin: 0px; padding: 0px;} ...

  9. [js开源组件开发]ajax分页组件

    ajax分页组件 我以平均每一周出一个开源的js组件为目标行动着,虽然每个组件并不是很庞大,它只完成某一个较小部分的工作,但相信,只要有付出,总会得到回报的.这个组件主要完成分页的工作. 这张图里显示 ...

随机推荐

  1. Dos命令 WIN10 WIFI命令

    设置WIFI命令: netsh wlan set hostednetwork ssid=T key=123456798 mode=allow netsh wlan start hostednetwor ...

  2. 在ubuntu下安装KDE以及完全卸载KDE

    自由转载 ^_^ 同时请注明原文出处:http://www.cnblogs.com/wangvsa/archive/2012/07/22/2603626.html 这是一篇翻译,很多不必要的东西就没翻 ...

  3. Mysql初识数据库《五》初识sql语句

    初识sql语句 有了mysql这个数据库软件,就可以将程序员从对数据的管理中解脱出来,专注于对程序逻辑的编写 mysql服务端软件即mysqld帮我们管理好文件夹以及文件,前提是作为使用者的我们,需要 ...

  4. Kylin -- Dup key found 问题

    kylin 构建 cube 时,抛出了如下的错误: org.apache.kylin.engine.mr.exception.HadoopShellException: java.lang.Runti ...

  5. 【spring】@Qualifier注解

    近期在捯饬spring的注解,现将遇到的问题记录下来,以供遇到同样问题的童鞋解决~ 先说明下场景,代码如下: 有如下接口: public interface EmployeeService { pub ...

  6. luogu5212/bzoj2555 substring(后缀自动机+动态树)

    对字符串构建一个后缀自动机. 每次查询的就是在转移边上得到节点的parent树中后缀节点数量. 由于强制在线,可以用动态树维护后缀自动机parent树的子树和. 注意一个玄学的优化:每次在执行连边操作 ...

  7. SDUT OJ 数据结构实验之链表五:单链表的拆分

    数据结构实验之链表五:单链表的拆分 Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Discuss Problem Descr ...

  8. KVO - 观察自定义属性值

    1 . 声明属性&注册监听 { BOOL isOk; } [self addObserver:self forKeyPath:@"isOk" options:0 conte ...

  9. (转)win7英文目录和中文目录,文件夹的别名

    win7英文目录和中文目录,文件夹的别名 在使用win7的很多目录例如我的文档.我的音乐等目录,你会发现文件夹是中文名的,路径也是中文的.但这个不是真的路径.点击一下地址栏,就可以看到真实路径了. 这 ...

  10. python学习之路---day03

    一:数据类型转换 1:bool-->int 将bool转成 int型 True 是1 False是0 a=True c=int(a) print(c) b=False d=int(b) prin ...