功能描述:分页,点击按钮或者下一页获取分页接口,同时active到对应页码。

html模块:

<page page-count="totalPage" on-click-page="reloadData(page)"></page>

controller模块:

var context = $scope;
#scope.reloadData = reloadData;//(重要:需要与页面的事件进行绑定)
function reloadData(page) {
context.params.pageNumber = page || 1;//将参数变为点击的page,默认为1
getPackageList(context.params);//请求后端分页接口(根据业务todo)
}

directive模块:

(function () {//自定义指令
appModule.directive('page', pageController);
function pageController() {
return {
restrict: 'AE',
templateUrl: '/directive/page.html',
scope: {
pageCount:'=',//对应totalPage
onClickPage:'&' //对应reloadData()
}, link: function( scope, elem, attrs, c){
var context = scope;
context.onClickPrev = onClickPrev;
context.onClickNext = onClickNext;
context.onClickPageNumber = onClickPageNumber;
       
       //$scope.watch为了兼容以前版本写法(如一开始就用这个分页组件,分页逻辑相同,可修改为下面一种写法)
!function init() { //!function init()效果和下面一样(这里做了老版本兼容)
context.pageNumber = 1;
scope.$watch(function () {
return context.pageCount//监听发现分页总数变了,执行后面函数
}, function () {
if (typeof context.pageCount != 'object' && typeof parseInt(context.pageCount) == 'number') {
var temp = [];
for (var i = 1; i <= context.pageCount; i++) {
temp.push(i);
}
context.pageCount = temp;
}
});
}();
       //分页逻辑相同,可直接将init写为这样(不用兼容以前)
       init();
       function init(){
        context.pageNumber = 1;
       }
 
function onClickPageNumber(pageNumber) {
context.onClickPage({page:pageNumber});//这里必须按着这种格式写,他是根据数组中的参数名对应来找
          //如果直接这样传参context.onClickPage(pageNumber),会报Cannot use 'in' operator to search for 'reloadData' in 2(寻找不到参数错误)
                context.pageNumber = pageNumber;
context.showPrev = pageNumber > 1;
} function onClickPrev() {
context.pageNumber -= 1;
context.onClickPage({message:context.pageNumber});
if (context.pageNumber == 1) {
context.showPrev = false;
}
context.showNext = true;
} function onClickNext() { if (context.pageNumber < context.pageCount.length) {
context.pageNumber += 1;
}
context.onClickPage({message:context.pageNumber});
}
}
};
}
})();

directive模板:

<div class="page-holder" ng-show="pageCount.length>1">
<span class="prev m-link" ng-if="pageNumber != 1" ng-click="onClickPrev()">&lt;</span>
<div style="display: inline" class="m-default"
    ng-repeat="page in pageCount track by $index" ng-show="($index+1>pageCount.length-5&&pageNumber>pageCount.length-3)||($index<5&&pageNumber<4)||($index+1>pageNumber-3 && $index+1<pageNumber+3)">
<span class="page m-link" ng-class="{'green':page == pageNumber}"
ng-click="onClickPageNumber(page)">{{page}}</span>
</div>
<span class="next m-link" ng-if="pageNumber != pageCount.length" ng-click="onClickNext()">&gt;</span>
<span class="total-page m-default">共 {{pageCount.length}} 页</span>
</span>
</div> <style>
.page-holder {
display: inline-block;
height: 30px;
line-height: 30px;
margin-right: 20px;
float: right;
} .page, .prev, .next, .total-page {
color: #616161;
padding: 0px 6px;
border:1px solid #f2f2f2;
} .green{
color:#0A9908;
}
</style> 效果如下:

  -----原创文章,©版权所有,转载请注明标明出处:http://www.cnblogs.com/doinbean
												

angular自定义分页组件(实用)的更多相关文章

  1. Angular4.+ ngx-bootstrap Pagination 自定义分页组件

    Angular4 随笔(二)  ——自定义分页组件 1.简介 本组件主要是实现了分页组件显示功能,通过使用 ngx-bootstrap Pagination分页组件实现. 基本逻辑: 1.创建一个分页 ...

  2. Python自定义分页组件

    为了防止XSS即跨站脚本攻击,需要加上 safe # 路由 from django.conf.urls import url from django.contrib import admin from ...

  3. Django框架---- 自定义分页组件

    分页的实现与使用 class Pagination(object): """ 自定义分页 """ def __init__(self,cur ...

  4. vue 自定义分页组件

    vue2.5自定义分页组件,可设置每页显示条数,带跳转框直接跳转到相应页面 Pagination.vue 效果如下图: all: small(只显示数字和上一页和下一页): html <temp ...

  5. 基于 Python 的自定义分页组件

    基于 Python 的自定义分页组件 分页是网页中经常用到的地方,所以将分页功能分出来,作为一个组件可以方便地使用. 分页实际上就是不同的 url ,通过这些 url 获取不同的数据. 业务逻辑简介 ...

  6. vue自定义分页组件---切图网

    vue2.5自定义分页组件 Pagination.vue,可设置每页显示条数,带跳转框直接跳转到相应页面,亲测有用.目前很多框架自带有分页组件比如elementUI,不过在面对一个拿到PSD稿,然后重 ...

  7. Flex4 自定义分页组件

    自己写的Flex4分页组件,去伪存真,只实现基本的分页功能,数据过滤神马的都不应该是分页组件干的活,有呆毛才有真相: [源代码下载] Flex自从转手给Apache后人气急跌,本人也很捉鸡,尽管Apa ...

  8. jquery ajax自定义分页组件(jquery.loehpagerv1.0)原创

    简单的两个步骤截可调用 <script src="<%=basePath%>/resources/js/jquery-1.7.1.min.js"></ ...

  9. Django 分页组件替换自定义分页

    Django的分页器(paginator) 总之不太好用我们还是用自己的好一些 自定义分页器 分页实现源码 """ 自定义分页组件 """ ...

随机推荐

  1. 71、django之Ajax续

    接上篇随笔.继续介绍ajax的使用. 上篇友情连接:http://www.cnblogs.com/liluning/p/7831169.html 本篇导航: Ajax响应参数 csrf 跨站请求伪造 ...

  2. SUID,SGID,SBIT这些到底是什么

    SUID,SGID,SBIT这些都是文件的特殊权限. SUID(Set UID)文件执行过程中,用户拥有文件的root权限. SGID(Set GID)文件执行过程中,执行者拥有该文件的用户组的权限. ...

  3. C#多功能DataGridView打印类(WinForm)

    ;                printPreviewDialog.ShowDialog();            }            catch            {         ...

  4. [转载] Storm:最火的流式处理框架

    转载自http://www.cnblogs.com/langtianya/p/5199529.html 伴随着信息科技日新月异的发展,信息呈现出爆发式的膨胀,人们获取信息的途径也更加多样.更加便捷,同 ...

  5. 自动化部署必备技能—部署yum仓库、定制rpm包

    部署yum仓库.定制rpm包 目录 第1章 扩展 - yum缓存 1.1 yum缓存使用步骤... 1 1.1.1 导言... 1 1.1.2 修改配置文件... 1 1.1.3 使用缓存... 1 ...

  6. linux操作系统基础篇(一)

    1.什么是linux? Linux是一套免费使用和自由传播的类Unix操作系统,是一个基于POSIX和UNIX的多用户.多任务.支持多线程和多CPU的操作系统.它能运行主要的UNIX工具软件.应用程序 ...

  7. Python之print字典

    在python 下面一个包含中文字符串的列表(list)或字典,直接使用print会出现以下的结果: >>> adict={'a':'中文'} >>> print ...

  8. boot之mybatis

    特别注意,此种方法和starter不兼容,我用了两个方式混蛋,发现跑不起来! spring: datasource: driver-class-name: com.mysql.cj.jdbc.Driv ...

  9. SQL Server 基本操作之三种增加法

    前言: 数据库操作避免不了对数据的操作,操作方法大同小异,万变不离其宗,今就写一下各种花式操作的根本增删改查四种操作,今天我们就来说一下增加操作的三种方法 正文: 增加操作是对数据库进行数据行的添加, ...

  10. 熟悉的“if __name__ == '__main__':”究竟是啥?

    print(__name__) # 直接手动运行,打印"__main__",当做模块导入(别处import)时打印脚本名字即"name_main" if __n ...