• AngularJS之Filter(二)


    前言

    本节我们来讲讲AngularJS中主要的部分之一,那就是过滤器,当从后台获取到的数据呈现到视图上时,此时可能需要对数据进行相应的转换,此时我们可以通过过滤器在不同页面进行不同数据的格式抓换,在AngularJS中有常见默认的过滤器,当然若不满足所需,我们可以自定义过滤器。

    AngularJS默认过滤器

    列举AngularJS中常见的过滤器,如下:

    过滤器名称 描述 例子
     currency  money格式化  {{ p.price | currency}}
     date  日期格式化  

    { p.orderDate | date : “dd MMM yyyy” }}

    {{ p.orderDate | date : “shortDate” }}

     json  将JSON字符串生成一个JSON对象  

    <tr ng-repeat="p in products">

    <td colspan="4">{{p | json}}</td>

    </tr>

     number  格式化数值并给出精确度位数  

    {{ p.price | number : 0}} 

    {{ p.price | number : 2}} 

     

    uppercase

    lowercase

     大小写转换  

    {{ p.city | lowercase }}

    {{ p.state | uppercase }}

     limitTo  控制列表渲染数据  <tr ng-repeat="p in products | limitTo:10">
     orderBy  排序  

    <tr ng-repeat="p in products | orderBy : ‘name’”>

    For descending order

    <tr ng-repeat="p in products | orderBy : ‘-name’”>

    默认过滤器示例

    我们渲染一个产品列表并将产品名称转换为大写,产品类别小写,以及数量保留两位小数等。

    UI

    <body ng-controller="FilterCtrl">  
        <div class="panel panel-default">  
            <div class="panel-heading">  
                <h3>  
                    产品个数  
                    <span class="label label-primary">{{products.length}}</span>  
                </h3>  
            </div>  
            <div class="panel-body">  
                <table class="table table-striped table-bordered table-condensed">  
                    <thead>  
                        <tr>  
                            <td>名称</td>  
                            <td>类别</td>  
                            <td>供给日期</td>  
                            <td class="text-right">数量</td>  
                            <td class="text-right">价格</td>  
                        </tr>  
                    </thead>  
                    <tbody>  
                        <tr ng-repeat="p in products | orderBy :'name'">  
                            <td>{{p.name | uppercase}}</td>  
                            <td>{{p.category | lowercase}}</td>  
                            <td>{{getExpiryDate(p.expiry) | date:"dd MMM yy"}}</td>  
                            <td class="text-right">{{p.quantity | number:2 }}</td>  
                            <td class="text-right">{{p.price | currency}}</td>  
                        </tr>  
                    </tbody>  
                </table>  
            </div>  
        </div>  
    </body>  

    JS

    app.controller('FilterCtrl', function ($scope) {  
        $scope.products = [  
                        { name: "Sony LED", category: "TV", price: 40000, quantity:10, expiry: 30 },  
                        { name: "Vivo xplay5", category: "Mobile", price: 35640, quantity: 08, expiry: 21 },  
                        { name: "LeTv", category: "TV", price: 36000, quantity: 5, expiry: 50 },  
                        { name: "Iphone 6 plus", category: "Mobile", price: 55000, quantity: 6, expiry: 60 },  
                        { name: "Galaxy s7 edge", category: "Mobile", price: 45000, quantity: 15, expiry: 50 },  
        ];  
      
        $scope.getExpiryDate = function (days) {  
            var now = new Date();  
            return now.setDate(now.getDate() + days);  
        }  
      
    });  

    最后生成如下:

    自定义过滤器示例 

    AngularJS不仅仅支持内部自构建的过滤器,而且还可以自定义过滤器来满足我们所需,若自定义过滤器此时我们需要 通过module.filter来实现,实际上内部是通过FilterProvider来实现。module.filter这个方法有两个参数,一个是需要创建的过滤器的名称,另外一个是创建一个factory函数来使得该自定义过滤器生效或者工作。

    接下来我们实现一个自定义过滤器,该过滤器带一个参数,实现了再对照代码就明朗了。如下:

    app.filter("properCase", function () {  
        return function (value, reverse) {  
            if (angular.isString(value)) {  
                var intermediate = reverse == false ? value.toUpperCase() : value.toLowerCase();  
                return (reverse == false ? intermediate[0].toLowerCase() :  
                intermediate[0].toUpperCase()) + intermediate.substr(1);  
            } else {  
                return value;  
            }  
        };  
    });  

    接下来在视图中将绑定的名称和类别修改成如下:

     <td>{{p.name | properCase}}</td>  
     <td>{{p.category | properCase : false}}</td>

    结果如下:

    混合过滤器示例 

    当进行渲染数据时,有可能需要进行多次过滤此时我们就需要创建多个自定义过滤器或者内置过滤器和自定义过滤器混合使用。

    我们首先对列表通过name来orderby一下,然后通过自定义过滤器移除前两条数据。

    app.filter("skipRec", function () {  
        return function (data, count) {  
            if (angular.isArray(data) && angular.isNumber(count)) {  
                if (count > data.length || count < 1) {  
                    return data;  
                } else {  
                    return data.slice(count);  
                }  
            } else {  
                return data;  
            }  
        }  
    });  

    此时视图页面循环列表时我们将修改成如下:

     <tr ng-repeat="p in products | orderBy :'name' | skipRec:2">  
     .......
     <tr>

    最终我们得到的结果如下:

    总结

    本节我们学习了AngularJS的过滤器,然后对默认过滤器、自定义过滤器以及混合过滤器统一进了相应的示例说明来加深理解,我们下节再见。

  • 相关阅读:
    速达5000出现计算成本数据溢出的问题
    速达软件 移动端 App 功能说明
    无法打开物理文件 操作系统错误 5: 5(拒绝访问。) 问题解决
    速达软件开发版使用技巧-销售开单单据打印格式设计
    开发版速达软件如何进行有效授权
    速达软件 移动端 App 下载试用
    速达软件二次开发-试用版本下载,欢迎合作
    速达软件开发版使用技巧-每页固定行样式报表设计
    Cause: org.postgresql.util.PSQLException: 栏位索引超过许可范围:13,栏位数:12
    springboot 开启事务回滚
  • 原文地址:https://www.cnblogs.com/CreateMyself/p/5527465.html
Copyright © 2020-2023  润新知