基本思路

一开始页码为1,Service向服务器端获取对应信息;点击上/下一页/跳转,通过对应的页码向服务器端获取对应的信息。

由于后台暂时没弄好,我实现的过程中直接读取准备好的JSON文件,通过页码获取对应的信息段并通过ng-repeat在页面显示具体信息。

展示

一开始直接在Controller中实现分页的功能代码

CSS部分

 /**
* Pagination
*/
.pagination{
margin: 40px auto 20px auto;
} .pagination ul{
width: 500px;
} .pagination-btn-group{
float: left;
margin-left: 40px;
} .pagination-btn-group:after{
display: table;
content: " ";
clear: both;
} .pagination ul li:hover,.pagination-btn-group div:hover{
cursor: pointer;
background-color: #B6B6B6;
color: #EBEBEB;
} .pagination-btn,.pagination-input,.pagination-next,.pagination-jmp,.pagination-prev{
display: block;
float: left;
height: 36px;
text-align: center;
margin-right: 8px;
border-radius: 5px;
margin-bottom: 40px;
}
.pagination-btn,.pagination-jmp{
background-color: #EBEBEB;
color: #B6B6B6;
line-height: 36px;
width: 60px;
} .pagination-input{
border-style: solid;
border-color: #B6B6B6;
border-width: 1px;
width: 60px;
} .pagination-next,.pagination-prev{
width: 80px;
background-color: #EBEBEB;
color: #B6B6B6;
line-height: 36px;
} .active{
background-color: #B6B6B6;
color: #EBEBEB;
} .disabled{
display: none;
}
/*end of pagination*/

HTML部分

 <div class="pagination">
<ul>
<li class="pagination-btn" ng-class="{true:'active'}[currentPage == page]" ng-repeat="page in pages" ng-click="selectPage(page)">
{{page}}
</li>
<input class="pagination-input" ng-model="destPage">
<li class="pagination-jmp" ng-click="skipPage()">跳转</li>
</ul>
<div class="pagination-btn-group">
<div class="pagination-prev" ng-click="prevPage()" ng-class="{true:'disabled'}[currentPage == 1]">&lt;上一页</div>
<div class="pagination-next" ng-click="nextPage()" ng-class="{true:'disabled'}[currentPage == endPage]">下一页&gt;</div>
</div>
</div>

ng-class="{true:'active'}[currentPage == page]" 表示当page为当前页面时应用.active的CSS样式

在angular中为我们提供了3种方案处理class:

1.scope变量绑定

  如:<div class=”{{test}}”></div> 然后在Controller中设置$scope.test值,不推荐使用,Controller中应该放业务逻辑部分,Service与服务器交互,Directive与页面交互

2.字符串数组形式

  形如:<div ng-class="{true: 'active', false: 'inactive'}[expression]"> expression为true,则active;否则inactive

3.对象key/value处理

  形如:<div ng-class {'selected': isSelected, 'car': isCar}"> isSelected为true,增加.selected样式;isCar为true,增加car样式

功能部分

 $scope.loadPagination = function() {
$scope.pages = [];
var i,j; if($scope.currentPage == "1..."){
$scope.currentPage = 1;
}else if($scope.currentPage == "..." + $scope.endPage){
$scope.currentPage = $scope.endPage;
} if(($scope.endPage <= 5) || ($scope.currentPage <= 3)){
$scope.pages[0] = 1;
for(i = 1;i < 5;i++){
if(i == $scope.endPage)
break;
$scope.pages[i] = i + 1;
}
if(i < $scope.endPage){
$scope.pages[4] = "..." + $scope.endPage;
}
}else if($scope.currentPage <= $scope.endPage-3){
$scope.pages[0] = "1...";
$scope.pages[1] = $scope.currentPage - 1;
$scope.pages[2] = $scope.currentPage;
$scope.pages[3] = $scope.currentPage + 1;
$scope.pages[4] = "..." + $scope.endPage;
}else{
$scope.pages[0] = "1...";
$scope.pages[1] = $scope.endPage - 3;
$scope.pages[2] = $scope.endPage - 2;
$scope.pages[3] = $scope.endPage - 1;
$scope.pages[4] = $scope.endPage;
} var start=($scope.currentPage - 1) * $scope.pageSize;
var end=$scope.currentPage * $scope.pageSize;
$scope.dialogList = $scope.realDialogList.slice(start,end);
}; $scope.prevPage = function() {
$scope.currentPage -= 1;
$scope.loadPagination();
}; $scope.nextPage = function() {
$scope.currentPage += 1;
$scope.loadPagination();
}; $scope.skipPage = function() {
var destPage=Number($scope.destPage);
$scope.destPage = "";
if(isNaN(destPage) || destPage <= 0 || destPage > $scope.endPage){
return ;
}
$scope.currentPage = destPage;
$scope.loadPagination();
}; $scope.selectPage = function(selected) {
$scope.currentPage=selected;
$scope.loadPagination();
};

$scope.realDialogList为Service获取的JSON信息,$scope.dialogList为要展示在页面上的信息

这里关键就是loadPagination(),我的思路是设置5个按钮的分页,第一个按钮作为首页链接,最后一个按钮作为末页链接,剩下三个按钮,将当前页码设置为中间按钮 。

根据分页栏首/末页按钮数字分为三种状态:

  1. 首页为'1',此时 页码<=3 或 末页<=5,当末页>5时,设置为'...X'

  2. 首页为'1...',末页为'...X',此时 页码<=末页-3

  3. 首页位'1...',末页为‘X',其他情况

代码:http://pan.baidu.com/s/1hqEZi0s

推荐将分页写成Directive

AngularJS分页实现的更多相关文章

  1. 自定义angularjs分页控件

    继昨天写了knockoutjs+ jquery pagination+asp.net web Api 实现无刷新列表页 ,正好最近刚学习angularjs ,故琢磨着写一个angularjs版本的分页 ...

  2. AngularJS 分页

    前端源码: <div> <h1>列表页33</h1> <table> <thead> <tr><td>CandiID ...

  3. angularjs 分页精华代码

    //pageinfo $scope.pageSize=10;$scope.currentType={{ current_type }};$scope.currentPage={{ json_encod ...

  4. Angularjs 分页控件

    实现效果: 实现步骤: 1.分页页面:page.html,页面多余样式,需要自己去除. <div class="row" ng-show="conf.totalIt ...

  5. angularjs分页组件

    这是我第一次写博客,激动,首先,我也是个菜鸟,分享一下自己写的服务器端分页的代码,自己一步一步写的,其中也有参考别人的代码.技术比较渣,先这样了. // ====== 2019-1-3 ======/ ...

  6. 前端使用AngularJS的$resource,后端ASP.NET Web API,实现分页、过滤

    在上一篇中实现了增删改查,本篇实现分页和过滤. 本系列包括: 1.前端使用AngularJS的$resource,后端ASP.NET Web API,实现增删改查2.前端使用AngularJS的$re ...

  7. Angularjs 跳转页面并传递参数的方法总结

    http://www.zhihu.com/question/33565135 http://www.codeproject.com/Articles/1073780/ASP-NET-MVC-CRUD- ...

  8. angular.js分页代码的实例

    对于大多数web应用来说显示项目列表是一种很常见的任务.通常情况下,我们的数据会比较多,无法很好地显示在单个页面中.在这种情况下,我们需要把数据以页的方式来展示,同时带有转到上一页和下一页的功能.现在 ...

  9. 有了jsRender,妈妈再也不用担心我用jq拼接DOM拼接的一团糟了、页面整齐了、其他伙伴读代码也不那么费劲了

    写在前面 说来也很巧, 下午再做一个页面,再普通不过的分页列表,我还是像往常一样,基于MVC环境下,我正常用PagedList.MVC AJAX做无刷新分页,这时候问题就来了,列表数据中有个轮播图用到 ...

随机推荐

  1. Razor语法学习

    原文:http://www.cnblogs.com/youring2/archive/2011/07/24/2115254.html 1.Razor的文件类型 Razor支持两种文件类型,分别是.cs ...

  2. 动态修改 NodeJS 程序中的变量值

    如果一个 NodeJS 进程正在运行,有办法修改程序中的变量值么?答案是:通过 V8 的 Debugger 接口可以!本文将详细介绍实现步骤. 启动一个 HTTP Server 用简单的 Hello ...

  3. 有了 Docker,用 JavaScript 框架开发的 Web 站点也能很好地支持网络爬虫的内容抓取

    点这里 阅读目录 用 AngularJS(以及其它 JavaScript 框架)开发的 Web 站点不支持爬虫的抓取 解决方案 为什么公开我们的解决方案 实现 AngularJS 服务 结论   Pr ...

  4. (0)图像处理opengl 写在前面的话

    项目2,终于要开始了 很多波折,都不想说了 开始吧 以下内容参考网上资料 OpenGL(Open Graphics Library)是一个跨编程语言.跨平台的专业图形程序接口. OpenGL是SGI公 ...

  5. CS001: 清理浮动的几种方法以及对应规范说明

    以下内容转自 http://www.w3help.org/zh-cn/casestudies/001 <!==================> 前言 浮动 Floats 是 CSS 中的 ...

  6. hdu 4159 Indomie (DP,数学概率)

    推出数学公式: #include<stdio.h> #include<string.h> __int64 C(int m,int n) { __int64 tmp=; if(m ...

  7. I,P,B帧和PTS,DTS的关系

    http://www.cnblogs.com/qingquan/archive/2011/07/27/2118967.html 基本概念: I frame :帧内编码帧 又称intra picture ...

  8. Java多线程-线程的调度(合并)

    线程的合并的含义就是将几个并行线程的线程合并为一个单线程执行,应用场景是当一个线程必须等待另一个线程执行完毕才能执行时可以使用join方法. join为非静态方法,定义如下:void join(): ...

  9. 点击UITableView的cell展开收缩

    在项目中有个需求,点击表视图的单元格展开,再点击另外一个单元格或者本身又收缩,经过一段时间尝试,实现了该功能,现在记录分享总结下.   首先要理解UITableView代理方法调用的先后顺序.   当 ...

  10. Java-马士兵设计模式学习笔记-责任链模式-模拟处理Reques Response

    一.目标 1.用Filter模拟处理Request.Response 2.思路细节技巧: (1)Filter的doFilter方法改为doFilter(Request,Resopnse,FilterC ...