AngularJS之Filter

Posted Jeffcky

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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的过滤器,然后对默认过滤器、自定义过滤器以及混合过滤器统一进了相应的示例说明来加深理解,我们下节再见。

 

以上是关于AngularJS之Filter的主要内容,如果未能解决你的问题,请参考以下文章

AngularJS 之 过滤器 Filter

[Angularjs]asp.net mvc+angularjs+web api单页应用之CRUD操作

$filter 不是一个函数 AngularJS

八angularjs 中 filter在controller中的使用--避免多次遍历

angularJS使用ocLazyLoad实现js延迟加载

AngularJS的Filter用法详解