zoukankan      html  css  js  c++  java
  • 基于Angularjs实现分页

    转 http://www.cnblogs.com/sword-successful/archive/2015/06/28/4605222.html

    前言

           学习任何一门语言前肯定是有业务需求来驱动你去学习它,当然ng也不例外,在学习ng前我第一个想做的demo就是基于ng实现分页,除去基本的计算思路外就是使用指令封装成一个插件,在需要分页的列表页面内直接引用。

    插件

          在封装分页插件时我实现了几种方式总体都比较零散,最后找到了一个朋友(http://www.miaoyueyue.com/archives/813.html)封装的插件,觉还不错,读了下他的源码就直接在项目中使用了。

    原理和使用说明

          1、插件源码主要基于angular directive来实现。

          2、调用时关键地方是后台请求处理函数,也就是从后台取数据。

          3、插件有两个关键参数currentPage、itemsPerPage,当前页码和每页的记录数。

          4、实现方法调用后我们需要根据每次点击分页插件页码时重新提交后台来获取相应页码数据。 在调用的页码中我使用了$watch来监控。  我初次使用时是把调用函数放在了插件的onchange中,结果发现每次都会触发两次后台。这个地方需要注意。

          5、我把请求后台封装成了Service层,然后在Controller里调用,也符合MVC思想。

    效果图

    调用代码

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    <div ng-app="DemoApp" ng-controller="DemoController">
        <table class="table table-striped">
            <thead>
                <tr>
                    <td>ID</td>
                    <td>FirstName</td>
                    <td>LastName</td>
                    <td>Status</td>
                    <td>Address</td>
                </tr>
            </thead>
            <tbody>
                <tr ng-repeat="emp in persons">
                    <td>{{emp.ID}}</td>
                    <td>{{emp.FirstName}}</td>
                    <td>{{emp.LastName}}</td>
                    <td>{{emp.Status}}</td>
                    <td>{{emp.Address}}</td>
                </tr>
            </tbody>
        </table>
        <tm-pagination conf="paginationConf"></tm-pagination>
    </div>
    <script type="text/javascript">
        var app = angular.module('DemoApp', ['tm.pagination']);
     
        app.controller('DemoController', ['$scope''BusinessService'function ($scope, BusinessService) {
     
            var GetAllEmployee = function () {
     
                var postData = {
                    pageIndex: $scope.paginationConf.currentPage,
                    pageSize: $scope.paginationConf.itemsPerPage
                }
     
                BusinessService.list(postData).success(function (response) {
                    $scope.paginationConf.totalItems = response.count;
                    $scope.persons = response.items;
                });
     
            }
     
            //配置分页基本参数
            $scope.paginationConf = {
                currentPage: 1,
                itemsPerPage: 5
            };
     
            /***************************************************************
            当页码和页面记录数发生变化时监控后台查询
            如果把currentPage和itemsPerPage分开监控的话则会触发两次后台事件。
            ***************************************************************/
            $scope.$watch('paginationConf.currentPage + paginationConf.itemsPerPage', GetAllEmployee);
        }]);
     
     
        //业务类
        app.factory('BusinessService', ['$http'function ($http) {
            var list = function (postData) {
                return $http.post('/Employee/GetAllEmployee', postData);
            }
     
            return {
                list: function (postData) {
                    return list(postData);
                }
            }
        }]);
    </script>
  • 相关阅读:
    计算器算法的简单实现
    [备忘]如何在Asp.net MVC,非Controller中获取当前Request,Session,Response等请求信息
    [Easy UI ]DataGrid 首次进入页面时,不加载任何数据
    使用Hyperv搭建oracle11gR2 RAC过程中遇到问题记录
    Win oracle10g 不同目录rman恢复记录
    ORACLE RAC 日常管理[10g,11g]
    win2008 11gRAC 环境 安装步骤记录 【前期配置简略】
    本地登录和远程登陆总结[oracle ,资料收集于网络]
    Oracle10g RAC 修改IP [转载]
    安装DNS Server linux 【转载】
  • 原文地址:https://www.cnblogs.com/ilinuxer/p/5246007.html
Copyright © 2011-2022 走看看