一、过滤器的作用

过滤器用来格式化须要展示给用户的数据。

在HTML中的模板绑定符号{{ }}内通过|符号来调用过滤器。

比如。如果我们希望将字符串转换成大写能够对字符串中的每一个字符都单独进行转换操作。也能够使用过滤器:{{name | uppercase }}

◇给过滤器传參数:

<h3>货币格式</h3>

{{123|currency}}

<H3>小数位数</H3>

{{123.3213132|number:2}}

<H3>大写转换</H3>

{{'tanzhenngqiang'|uppercase}}

<H3>小写转换</H3>

{{'TANZHENGQIANG'|lowercase}}

◆number过滤器将数字格式化成文本。它的第二个參数是可选的。用来控制小数点后截取的位数。

假设传入了一个非数字字符,会返会空字符串

◆能够用|符号作为切割符来同一时候使用多个过滤器。

二、filter过滤器

能够从给定数组中选择一个子集,并将其生成一个新数组返回。这个过滤器通经常使用来过滤须要进行展示的元素。比如,在做client搜索时。能够从一个数组中立马过滤出所需的结果。

这个过滤器的第一个參数能够是字符串、对象或是一个用来从数组中选择元素的函数。

演示样例:

①过滤包括字母e的单词

{{['Ari','Lerner','Likes','To','Eat','Pizza'] | filter:'e' }}

②过滤对象

{{ [

{ 'name': 'Ari',

'City': 'San Francisco',

'favorite food': 'Pizza' },

{ 'name': 'Nate',

'City': 'San Francisco',

'favorite food': 'indianfood'

}] | filter:{'favorite food': 'Pizza'} }}

③自己定义函数进行过滤

◇isCapitalized函数的功能是依据首字母是否为大写返回true或false。

$scope.isCapitalized= function(str) {

return str[0] == str[0].toUpperCase();

};

使用自己定义过滤函数

{{['Ari','likes','to','travel'] | filter:isCapitalized }}

<!--["Ari"] -->

我们也能够给filter过滤器传入第二个參数,用来指定预期值同实际值进行比較的方式。

第二个參数能够是下面三种情况之中的一个。

◇true

用angular.equals(expected, actual)对两个值进行严格比較。

◇ false

进行区分大写和小写的子字符串比較。

◇函数

执行这个函数,假设返回真值就接受这个元素。

★JSON过滤器

json过滤器能够将一个JSON或JavaScript对象转换成字符串。这样的转换对调试很有帮助,比如:

{{ {'name':'Ari', 'City': 'SanFrancisco'} | json }}

<!--

{

"name": "Ari",

"City": "San Francisco"

}

-->

★limitTo过滤器(截取字符串)

limitTo过滤器会依据传入的參数生成一个新的数组或字符串,新的数组或字符串的长度取决于传入的參数,通过传入參数的正负值来控制从前面还是从后面開始截取。

假设传入的长度值大于被操作数组或字符串的长度。那么整个数组或字符串都会被返回。

比如,我们能够截取字符串的前三个字符:

{{ San Francisco is very cloudy | limitTo:3 }}

<!-- San -->

或最后的六个字符:

{{ San Francisco is very cloudy | limitTo:-6 }}

<!-- cloudy -->

对数组也能够进行相同的操作。返回数组的第一个元素:

{{ ['a','b','c','d','e','f'] | limitTo:1 }}

<!--["a"] -->

★orderBy过滤器

orderBy过滤器能够用表达式对指定的数组进行排序。orderBy能够接受两个參数,第一个是必需的,第二个是可选的。

第一个參数是用来确定数组排序方向的谓词。

以下分情况讨论第一个參数的类型。

l 函数

当第一个參数是函数时。该函数会被当作待排序对象的getter方法。

l 字符串

对这个字符串进行解析的结果将决定数组元素的排序方向。

能够传入+或-来强制进行升序或降序排列。

l 数组

在排序表达式中使用数组元素作为谓词。对与表达式结果并不严格相等的每一个元素。则使用第一个谓词。

第二个參数用来控制排序的方向(是否逆向)。

{{ [{

'name': 'Ari',

'status': 'awake'

},{

'name': 'Q',

'status': 'sleeping'

},{

'name': 'Nate',

'status': 'awake'

}] | orderBy:'name' }}

结果:

[

{"name":"Ari","status":"awake"},

{"name":"Nate","status":"awake"},

{"name":"Q","status":"sleeping"}

]

也能够对排序结果进行反转。比如,通过将第二个參数设置为true能够将排序结果进行反转:

{{ [{

'name': 'Ari',

'status': 'awake'

},{

'name': 'Q',

'status': 'sleeping'

},{

'name': 'Nate',

'status': 'awake'

}] | orderBy:'name':true }}

三、自己定义过滤器

创建自己定义过滤器须要将它放到自己的模块中。

◇实现一个过滤器,将字符串第一个字母转换为大写。

过滤器本质上是一个会把我们输入的内容当作參数传入进去的函数。上面这个样例中,我们在调用过滤器时简单地把input当作字符串来处理。

能够在这个函数中做一些错误检查:

angular.module('myApp.filters', []).filter('capitalize',function()
{

returnfunction(input)
{

// input是我们传入的字符串

if (input) {

return input[0].toUpperCase() + input.slice(1);

}

};

});

如今,假设想将一个句子的首字母转换成大写形式,能够用过滤器先将整个句子都转换成小

写。再把首字母转换成大写:

<!-- Ginger loves dog treats -->

{{ 'ginger loves dog treats' | lowercase | capitalize}}

4、angularJS过滤器的更多相关文章

  1. AngularJS过滤器filter-时间日期格式-渲染日期格式-$filter

    今天遇到了这些问题索性就 写篇文章吧 话不多说直接上栗子 不管任何是HTML格式还是JS格式必须要在  controller 里面写 // new Date() 获取当前时间 yyyy-MM-ddd ...

  2. AngularJS 过滤器

    过滤器可以使用一个管道字符(|)添加到表达式和指令中 AngularJS 过滤器可用于转换数据: currency 格式化数字为货币格式. filter 从数组项中选择一个子集. lowercase ...

  3. AngularJS过滤器

    1.过滤器可以使用一个管道字符(|)添加到表达式和指令中. 再次强调一点,所有的运行都要加入angularJS的库文件(类似JQuery的引用) 常见的AngularJS 过滤器 (1) lowerc ...

  4. AngularJS学习之旅—AngularJS 过滤器(七)

    1.AngularJS 过滤器 过滤器可以使用一个管道字符(|)添加到表达式和指令中. AngularJS 过滤器可用于转换数据: 过滤器 描述 currency 格式化数字为货币格式. filter ...

  5. AngularJS 1.x系列:AngularJS过滤器(4)

    1. AngularJS过滤器(Filter)使用方法 AngularJS中过滤器(Filter)主要功能是格式化数据. AngularJS过滤器使用方法有3种: ◊ 在表达式{{}}中使用 ◊ 在指 ...

  6. AngularJS过滤器filter入门

    在开发中,经常会遇到这样的场景 如用户的性别分为“男”和“女”,在数据库中保存的值为1和0,用户在查看自己的性别时后端返回的值自然是1或0,前端要转换为“男”或“女”再显示出来: 如我要换个羽毛球拍, ...

  7. AngularJS控制器和AngularJS过滤器的学习(3)

    前面简单的学习了AngularJS的表达式和指令,就可以说大概对AngularJS有了一定的了解吧,嘿嘿,下面就来总结学习一下AngularJS的控制器和过滤器哦. 说起来AngularJS控制器,其 ...

  8. angularJS 过滤器 表单验证

    过滤器1.filter的作用就是接收一个输入,通过某个规则进行处理,然后返回处理后的结果,主要用于数据的格式化.2.内置过滤器(1)Currency(货币)将一个数值格式化为货币格式,默认为$(2)D ...

  9. angularjs过滤器(一)------禁止转载------

    如果用代码实现:将new Date()转换为 M/D/YY 00:00 格式. 启用过滤器有两种方式:①在HTML中用"|"启用过滤器.格式为{{$scope.property | ...

  10. 关于angularjs过滤器的小尝试

    最近的项目中用到了angularjs,相比传统的jquery直接操作Dom, 开发web项目,angularjs在操作表格数据时的数据绑定,操作让我不禁直呼过瘾,好方便啊, 从后台接口传一个json过 ...

随机推荐

  1. tomcat生成catalina.out文件

    生成catalina.out方法 导语:本文为Windows下生tomcat将控制台信息输出到catalina.out文件  且 保证能实时查看日志文件的方法. 一.创建catalina.out 1. ...

  2. python gdal 矢量转栅格

    data = gdal.Open(templateTifFileName, gdalconst.GA_ReadOnly)geo_transform = data.GetGeoTransform()x_ ...

  3. [Windows Server 2003] 安装PHP+MySQL方法

    ★ 欢迎来到[护卫神·V课堂],网站地址:http://v.huweishen.com★ 护卫神·V课堂 是护卫神旗下专业提供服务器教学视频的网站,每周更新视频.★ 本节我们将带领大家:PHP+MyS ...

  4. ddrmenu

    <%@ Register TagPrefix="dnn" TagName="MENU" Src="~/DesktopModules/DDRMen ...

  5. PHP7安装Memcache+Memcached缓存加速WordPress教程

    PHP7安装Memcache+Memcached缓存加速WordPress教程 2016年1月19日 6,691 Views 生活方式 PHP7最显著的变化就是性能的极大提升,已接近Facebook开 ...

  6. javascript常用功能函数

    特殊字符转义:将<, >, &, “进行转义 function escape(str){ return str.replace(/[<>"&]/g,f ...

  7. layer:好看的弹出窗口

    layer是一款web弹层组件,只需在调用时简单地配置相关参数,即可轻松实现丰富与便捷的操作体验. 这是layer的官方地址,里面的使用介绍非常详细(http://layer.layui.com/) ...

  8. 【Centos7】Tomcat安装及一个服务器配置多个Tomcat

    完成解压 参考 http://www.cnblogs.com/h--d/p/5074800.html https://www.cnblogs.com/tudou-22/p/9330875.html 步 ...

  9. 一个ROS的服务,使机器人向前移动指定距离

    源代码有点长,放文末链接里了. 服务描述及代码现在的服务是:请求时携带要前进的距离,然后底盘前进相应距离.代码如下,改动很小: #!/usr/bin/env python import rospyfr ...

  10. The JVM Architecture Explained

    转自:https://dzone.com/articles/jvm-architecture-explained?oid=18544920 Every Java developer knows tha ...