angularjs之filter过滤器

  现在公司用ionic,就是基于angularjs封装了一些api用于webapp,最近用的angularjs的filter确实省了很多代码,现在总结一下!

  ng比较鸡肋的过滤器,这里就一笔带过吧!鸡汤类常用的filter后面上例子。

lowercase(小写)

{{ lastName | lowercase }}

uppercase(大写)

{{ lastName | uppercase }}

number(格式化数字)

number过滤器可以为一个数字加上千位分割,像这样,123,456,789。同时接收一个参数,可以指定小float型保留几位小数:

{{ num | number : 2 }}

currency (货币处理)

{{num | currency : ‘¥‘}}

json(格式化json对象)

{{ jsonTest | json}}

  作用就和我们熟悉的JSON.stringify()一样

limitTo(限制数组长度或字符串长度)

{{ childrenArray | limitTo : 3 }}  //将会显示数组中的前3项

filter(匹配子串)

  用来处理一个数组,然后可以过滤出含有某个子串的元素,作为一个子数组来返回。可以是字符串数组,也可以是对象数组。如果是对象数组,可以匹配属性的值。它接收一个参数,用来定义子串的匹配规则。

html

<ul>
        <li>filter 匹配子串(以下写法只是方便观察)</li>
        <li>{{ webArr | filter : ‘n‘ }} <!--匹配属性值中含有n的--></li>
        <li>{{ webArr | filter : 25 }} <!--匹配属性值中含有25的--></li>
        <li>{{ webArr | filter : {name : ‘l‘} }} <!--//参数是对象,匹配name属性中含有l的--></li>
        <li>{{ webArr | filter : fun }} <!--/参数是函数,指定返回age>25的--></li>
</ul>

js

$scope.webArr = [
                    {name:‘nick‘,age:25},
                    {name:‘ljy‘,age:28},
                    {name:‘xzl‘,age:28},
                    {name:‘zyh‘,age:30}
                ];
$scope.fun = function(e){return e.age>25;};

效果展示:

filter 匹配子串(以下写法只是方便观察)
[{"name":"nick","age":25}]
[{"name":"nick","age":25}]
[{"name":"ljy","age":28},{"name":"xzl","age":28}]
[{"name":"ljy","age":28},{"name":"xzl","age":28},{"name":"zyh","age":30}]

日期类

  日期过滤器应该是常用过滤器中最简单的吧!

  • yyyy--表示年份;
  • MM--月份(必须大写);
  • dd--日期;
  • hh--时;
  • mm--分(必须小写);
  • ss--秒;
  • EEEE--星期;
  • hh:mm--形式是24小时制;
  • h:mma--12小时制;
  • 其中年、月、日、时、分、秒 或  / : - 等自己试做搭配吧!
    <ul>
        <li>8 日期1</li>
        <li ng-bind="date|date:‘yyyy/MM/dd hh:mm:ss EEEE‘"></li>
        <li>8 日期2</li>
        <li ng-bind="date|date:‘yyyy年MM月dd日 h:mma EEEE‘"></li>
        <li>8 日期3</li>
        <li ng-bind="date|date:‘yyyy年MM月dd日 hh时mm分ss秒‘"></li>
        <li>8 日期4</li>
        <li ng-bind="date|date:‘yyyy/MM/dd hh:mm:ss‘"></li>
    </ul>

日期1的显示效果:

2016/11/19 11:59:05 Saturday

日期2的显示效果:

2016年11月19日 12:01PM Saturday

日期3的显示效果:

2016年11月22日 10时42分09秒

日期4的显示效果:

2016/11/22 11:16:58

orderBy排序(个人认为第七例最佳写法)

ng-repeat生成一个独立的scope作用域,直接在ng-repeat循环后加管道orderBy排序。

用法很简单,但有坑需注意两点:

  • 参数引号勿忘;
  • 参数形式--直接写成age,不用写成item2.age。

3 按年龄排序(默认升序)

    <ul>
        <li>3 按年龄排序(默认升序)</li>
        <li ng-repeat="item2 in items2|orderBy:‘age‘">
            <div>
                <b>name</b>
                <u ng-bind="item2.name"></u>
            </div>
            <div>
                <b>age</b>
                <i ng-bind="item2.age"></i>
            </div>
            <div>
                <b>stature</b>
                <i ng-bind="item2.stature"></i>
            </div>
        </li>
    </ul>

效果展示:

3 按年龄排序(默认升序)
name ljy
age 27
stature 165
name nick
age 25
stature 170
name xzl
age 27
stature 175
name zyh
age 29
stature 165

4 按年龄排序(加参数true则为倒序即降序)

    <ul>
        <li ng-repeat="item2 in items2|orderBy:‘age‘:true">
            <div>
                <b>name</b>
                <u ng-bind="item2.name"></u>
            </div>
            <div>
                <b>age</b>
                <i ng-bind="item2.age"></i>
            </div>
            <div>
                <b>stature</b>
                <i ng-bind="item2.stature"></i>
            </div>
        </li>
    </ul>

效果展示:

4 按年龄排序(加参数true则为倒序即降序)
name zyh
age 29
stature 165
name xzl
age 27
stature 175
name ljy
age 27
stature 165
name nick
age 25
stature 170
5 想先按年龄升序在按身高降序(全是降序了,达不到效果,见第7例)我曾就天真的这样写过^*^
    <ul>
        <!--<li ng-repeat="item2 in items2|orderBy:‘age‘:‘-stature‘">-->
        <li ng-repeat="item2 in items2|orderBy:‘age‘:‘stature‘:true">
            <div>
                <b>name</b>
                <u ng-bind="item2.name"></u>
            </div>
            <div>
                <b>age</b>
                <i ng-bind="item2.age"></i>
            </div>
            <div>
                <b>stature</b>
                <i ng-bind="item2.stature"></i>
            </div>
        </li>
    </ul>

效果展示:

5 想先按年龄升序在按身高降序(全是降序了,达不到效果,见第7例)
name zyh
age 29
stature 165
name xzl
age 27
stature 175
name ljy
age 27
stature 165
name nick
age 25
stature 170

6 先按年龄在按身高排序(多个参数写出数组形式)

    <ul>
        <li ng-repeat="item2 in items2|orderBy:[‘age‘,‘stature‘]">
            <div>
                <b>name</b>
                <u ng-bind="item2.name"></u>
            </div>
            <div>
                <b>age</b>
                <i ng-bind="item2.age"></i>
            </div>
            <div>
                <b>stature</b>
                <i ng-bind="item2.stature"></i>
            </div>
        </li>
    </ul>

效果展示:

6 先按年龄在按身高排序(多个参数写出数组形式)
name nick
age 25
stature 170
name ljy
age 27
stature 165
name xzl
age 27
stature 175
name zyh
age 29
stature 165

7 先按年龄升序在按身高降序(多个参数写出数组形式)

  在参数前加负号即可实现倒序

    <ul>
        <li ng-repeat="item2 in items2|orderBy:[‘age‘,‘-stature‘]">
            <div>
                <b>name</b>
                <u ng-bind="item2.name"></u>
            </div>
            <div>
                <b>age</b>
                <i ng-bind="item2.age"></i>
            </div>
            <div>
                <b>stature</b>
                <i ng-bind="item2.stature"></i>
            </div>
        </li>
    </ul>

效果展示:

!!7 先按年龄升序在按身高降序(多个参数写出数组形式)
name nick
age 25
stature 170
name xzl
age 27
stature 175
name ljy
age 27
stature 165
name zyh
age 29
stature 165

个人觉得ng内置的过滤器好多都比较鸡肋。个性化的需求自定义的过滤器吧。

自定义过滤器

自定义过滤器就是返回一个函数,函数又返回你要的值即可!

实例:

angular.module(‘youAppName‘,[])
                .filter(‘youFilterName‘,function(){
                    return function(){
                      //你的处理代码
                        return result;//返回你要的值
                    }
                })

自定义一个求和的过滤器

html

    <ul>
        <li>!!1 求和</li>
        <li ng-repeat="item1 in items1">
            <div ng-bind="item1.male | sumNick:item1.female:item1.gay"></div>
        </li>
    </ul>

用法:

管道前后所有参数即为和

js

var nickAppModule=angular.module(‘nickApp‘,[]);
        nickAppModule
                //求和
                .filter(‘sumNick‘,function(){
                    return function(){
                        var arr=Array.prototype.slice.call(arguments),sum=0;
                        for(var i= 0,len=arr.length;i<len;i++){
                            sum+=arr[i]?arr[i]:0;
                        }
                        return sum;
                    }
                })

arguments--函数接受的参数集合,类数组;

Array.prototype.slice.call(arguments)

这句将类数组转为数组;

 sum+=arr[i]?arr[i]:0;

  总和sum等于数组的每个元素累加的和。避免后台为传值,而又将次参数传人自定义filer函数作为参数,容错时写成0保险。

  自定义一个求百分百的过滤器(求保留小数点后两位百分比)

html

    <ul ng-repeat="item1 in items1">
        <li>!!2 求百分比</li>
        <li>
            <b>male</b>
            <i ng-bind="item1.male|percentNick:item1.female:item1.gay"></i>
        </li>
        <li>
            <b>female</b>
            <u ng-bind="item1.female|percentNick:item1.male:item1.gay"></u>
        </li>
        <li>
            <b>gay</b>
            <s ng-bind="item1.gay|percentNick:item1.female:item1.male"></s>
        </li>
    </ul>

用法:

 分子写在管道前面,管道后面的所有参数和加管道前的参数和则为分母

js

var nickAppModule=angular.module(‘nickApp‘,[]);
        nickAppModule
//百分比
                .filter(‘percentNick‘,function(){
                    return function(){
                        var arr=Array.prototype.slice.call(arguments),sum=0;
                        for(var i= 0,len=arr.length;i<len;i++){
                            sum+=arr[i]?arr[i]:0;
                        }
                        //0/0也是nan
                        return sum==0?‘0%‘:Math.round((arr[0]?arr[0]:0)/sum*10000)/100+"%";
                    }
                })

这里就是在上面求和的filter上多了一句:

sum==0?‘0%‘:Math.round((arr[0]?arr[0]:0)/sum*10000)/100+"%"

  Math内置函数,Math.round四舍五入保留整数;

  将总和乘以10000除以100拼接百分比号,即保留两位小数。

完整代码:

<!DOCTYPE html>
<html lang="zh-CN" ng-app="nickApp">
<head>
    <meta charset="UTF-8">
    <title>ng filter nick</title>
</head>
<body ng-controller="nickCtrl">
    <ul>
        <li>!!1 求和</li>
        <li ng-repeat="item1 in items1">
            <div ng-bind="item1.male | sumNick:item1.female:item1.gay"></div>
        </li>
    </ul>
    <ul ng-repeat="item1 in items1">
        <li>!!2 求百分比</li>
        <li>
            <b>male</b>
            <i ng-bind="item1.male|percentNick:item1.female:item1.gay"></i>
        </li>
        <li>
            <b>female</b>
            <u ng-bind="item1.female|percentNick:item1.male:item1.gay"></u>
        </li>
        <li>
            <b>gay</b>
            <s ng-bind="item1.gay|percentNick:item1.female:item1.male"></s>
        </li>
    </ul>
    <ul>
        <li>3 按年龄排序(默认升序)</li>
        <li ng-repeat="item2 in items2|orderBy:‘age‘">
            <div>
                <b>name</b>
                <u ng-bind="item2.name"></u>
            </div>
            <div>
                <b>age</b>
                <i ng-bind="item2.age"></i>
            </div>
            <div>
                <b>stature</b>
                <i ng-bind="item2.stature"></i>
            </div>
        </li>
    </ul>
    <ul>
        <li>4 按年龄排序(加参数true则为倒序即降序)</li>
        <li ng-repeat="item2 in items2|orderBy:‘age‘:true">
            <div>
                <b>name</b>
                <u ng-bind="item2.name"></u>
            </div>
            <div>
                <b>age</b>
                <i ng-bind="item2.age"></i>
            </div>
            <div>
                <b>stature</b>
                <i ng-bind="item2.stature"></i>
            </div>
        </li>
    </ul>
    <ul>
        <li>5 想先按年龄升序在按身高降序(全是降序了,达不到效果,见第7例)</li>
        <!--<li ng-repeat="item2 in items2|orderBy:‘age‘:‘-stature‘">-->
        <li ng-repeat="item2 in items2|orderBy:‘age‘:‘stature‘:true">
            <div>
                <b>name</b>
                <u ng-bind="item2.name"></u>
            </div>
            <div>
                <b>age</b>
                <i ng-bind="item2.age"></i>
            </div>
            <div>
                <b>stature</b>
                <i ng-bind="item2.stature"></i>
            </div>
        </li>
    </ul>
    <ul>
        <li>6 先按年龄在按身高排序(多个参数写出数组形式)</li>
        <li ng-repeat="item2 in items2|orderBy:[‘age‘,‘stature‘]">
            <div>
                <b>name</b>
                <u ng-bind="item2.name"></u>
            </div>
            <div>
                <b>age</b>
                <i ng-bind="item2.age"></i>
            </div>
            <div>
                <b>stature</b>
                <i ng-bind="item2.stature"></i>
            </div>
        </li>
    </ul>
    <ul>
        <li>!!7 先按年龄升序在按身高降序(多个参数写出数组形式)</li>
        <li ng-repeat="item2 in items2|orderBy:[‘age‘,‘-stature‘]">
            <div>
                <b>name</b>
                <u ng-bind="item2.name"></u>
            </div>
            <div>
                <b>age</b>
                <i ng-bind="item2.age"></i>
            </div>
            <div>
                <b>stature</b>
                <i ng-bind="item2.stature"></i>
            </div>
        </li>
    </ul>
    <ul>
        <li>8 日期1</li>
        <li ng-bind="date|date:‘yyyy/MM/dd hh:mm:ss EEEE‘"></li>
        <li>2016/11/19 11:59:05 Saturday</li>
        <li>8 日期2</li>
        <li ng-bind="date|date:‘yyyy年MM月dd日 h:mma EEEE‘"></li>
        <li>2016年11月19日 12:01PM Saturday</li>
        <li>8 日期3</li>
        <li ng-bind="date|date:‘yyyy年MM月dd日 hh时mm分ss秒‘"></li>
        <li>2016年11月22日 10时42分09秒</li>
        <li>8 日期4</li>
        <li ng-bind="date|date:‘yyyy/MM/dd hh:mm:ss‘"></li>
        <li>2016/11/22 11:16:58</li>
    </ul>
    <div>{{100000|currency:‘¥‘}}<!--¥可以写成$或其他--></div>
    <ul>
        <li>filter 匹配子串(以下写法只是方便观察)</li>
        <li>{{ webArr | filter : ‘n‘ }} <!--匹配属性值中含有n的--></li>
        <li>{{ webArr | filter : 25 }} <!--匹配属性值中含有25的--></li>
        <li>{{ webArr | filter : {name : ‘l‘} }} <!--//参数是对象,匹配name属性中含有l的--></li>
        <li>{{ webArr | filter : fun }} <!--/参数是函数,指定返回age>25的--></li>
    </ul>
    <script src="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script>
    <script>
        var nickAppModule=angular.module(‘nickApp‘,[]);
        nickAppModule
                //求和
                .filter(‘sumNick‘,function(){//管道前后所有参数和
                    return function(){
                        var arr=Array.prototype.slice.call(arguments),sum=0;
                        for(var i= 0,len=arr.length;i<len;i++){
                            sum+=arr[i]?arr[i]:0;
                        }
                        return sum;
                    }
                })
                //百分比
                .filter(‘percentNick‘,function(){//小数点后两位百分比 分子写在管道前面,管道后面的所有参数和加管道前的参数和为分母
                    return function(){
                        var arr=Array.prototype.slice.call(arguments),sum=0;
                        for(var i= 0,len=arr.length;i<len;i++){
                            sum+=arr[i]?arr[i]:0;
                        }
                        //0/0也是nan
                        return sum==0?‘0%‘:Math.round((arr[0]?arr[0]:0)/sum*10000)/100+"%";
                    }
                })
    </script>
<script>
    nickAppModule
            .controller(‘nickCtrl‘,[‘$scope‘,function($scope){
                $scope.items1=[{
                    male:66,
                    female:23,
                    gay:5,
                    other:‘xxx‘,
                    msg:‘xxx‘
                },
                    {
                        male:16,
                        female:8,
                        gay:7,
                        other:‘xxx‘,
                        msg:‘xxx‘
                    }];
                $scope.items2=[
                    {
                        name:‘ljy‘,
                        age:27,
                        stature:165
                    },
                    {
                        name:‘nick‘,
                        age:25,
                        stature:170
                    },
                    {
                        name:‘xzl‘,
                        age:27,
                        stature:175
                    },
                    {
                        name:‘zyh‘,
                        age:29,
                        stature:165
                    }];
                $scope.date=new Date();
                $scope.webArr = [
                    {name:‘nick‘,age:25},
                    {name:‘ljy‘,age:28},
                    {name:‘xzl‘,age:28},
                    {name:‘zyh‘,age:30}
                ];
                $scope.fun = function(e){return e.age>25;};
            }])

</script>
</body>
</html>

个人能力有限,浅显的总结了下ng filter,若有偏差,望大神指正!

时间: 2024-08-01 21:30:49

angularjs之filter过滤器的相关文章

【angularJS】Filter 过滤器

当从后台获取到的数据呈现到视图上时,此时可能需要对数据进行相应的转换,此时我们可以通过过滤器在不同页面进行不同数据的格式抓换,在AngularJS中有常见默认的过滤器,当然若不满足所需,我们可以自定义过滤器. AngularJS 过滤器可以用来格式化数据,过滤器能够用在表达式和指令中. 使用一个管道字符(|)添加到表达式和指令中. 默认过滤器 列举AngularJS中常见的过滤器,如下: 过滤器名称 描述 例子 currency money格式化 {{ p.price | currency}}

AngularJS学习之filter过滤器的用法

系统的学习angularjs,发现angularjs的有些思想根php的模块smarty很像,例如数据绑定,filter.如果对smarty比较熟悉的话,学习angularjs会比较容易一点.这篇简单说一下angularjs的filter功能,angularjs的filter功能可分为二种,一种是内置的过滤器,一种是自定义的. 一,内置的过滤器 1,uppercase,lowercase大小转换 {{ "lower cap string" | uppercase }}   //结果:L

AngularJS中的过滤器(filter)

AngularJS中的过滤器是用于对数据的格式化,或者筛选的函数,可以直接通过以下语法使用: {{expression|filter}} {{expression|filter1|filter2}} {{expression|filter1:param1,param2,...|filter2} 过滤器的种类有number,currency,date,json,limitTo,lowercase,uppercase,filter,orderBy. <!DOCTYPE html> <html

前端MVC学习总结——AngularJS验证、过滤器

前端MVC学习总结--AngularJS验证.过滤器 目录 一.验证 二.过滤器 2.1.内置过滤器 2.1.1.在模板中使用过滤器 2.1.2.在脚本中调用过滤函数 2.2.自定义过滤器 三.指令(directive) 3.1.支持AngularJS功能的指令 3.1.1.应用与模块(ng-app) 3.1.2.控制器(ng-Controller) 3.1.3.包含(ng-Include) 3.1.4.不绑定(ngNonBindable) 3.2.扩展表单元素的指令 3.2.1.ng-opti

estore商城案例(三)------Filter过滤器:自动登录&amp;权限管理

前面写好了用户登录\注册\添加商品的功能模块.下面写一下对于这些功能模块的相关过滤器---自动登录与权限管理: 一.自动登录: 业务逻辑是这样的:jsp登录页面有个“自动登录选项”,如果登录这勾选了,那么在serlvet程序中则会额外的生成一个保存用户名和密码的cookie,然后每次用户向服务器发送请求时,Filter过滤器都会先判断用户的登录状态(session),如果已经登录那么无需做出受任何操作直接放行,如果没有登录(无session),那么这时体现自动登录功能作用的时候到了,先获取自动登

Java Web总结十九Filter过滤器

一.Filter简介 Filter也称之为过滤器,它是Servlet技术中最激动人心的技术,Web开发人员通过Filter技术,对Web服务器管理的所有Web资源:例如Jsp,Servlet,静态图片文件或静态HTML文件等进行拦截,从而实现一些特殊的功能.例如实现URL级别的权限访问控制.过滤敏感词汇.自动登录.压缩响应信息等一些高级功能. Servlet API中提供了一个Filter接口,开发Web应用时,如果编写的Java类实现了这个接口,则把这个Java类称之为过滤器Filter.通过

SSH2——filter过滤器

概述: 过滤器是Servlet2.3以上新增加的一个功能,其技术也是非常强大的.通过Filter技术可以对WEB服务器的文件进行拦截,从而实现一些特殊的功能.在JSP开发应用中也是必备的技能之一.Filter可以改变一个request(请求)和修改一个response(响应).Filter不是一个Servlet,它不能产生一个response,它能够在一个requsst到达Servlet之前预处理request,也可以在离开Servlet时处理response. 原理: 当Web容器接受到一个对

AngularJS 霸道的过滤器

学习要点 为什么使用过滤器 过滤单个数据的值 格式化货币值 格式化数字值 格式化日期 改变字符串大小写 生成JSON 本地化过滤器输出 过滤集合 限制项目数量 选取项 对项目排序 链式过滤器 自定义过滤器 创建格式化数据值的过滤器 创建集合过滤器 在已有过滤器上搭建新的过滤器 一.为什么使用过滤器? 在实际操作中,我们需要对统一数据源进行多次转换,比如我的货币单位,在不同的国家我们将用不同的符号表示.因此,你可能会想到在控制器中判断国家以显示不同的结果,但是过滤器却可以更好的帮助我们做到同样的效

filter 过滤器从数组中选择一个子集

输入过滤器可以通过一个管道字符和一个过滤器添加到指令中,该过滤器后面跟着一个冒号:冒号后面是一个模型名称. <!DOCTYPE html><html><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <meta http-equiv="X-UA-Compatible"content="