一、过滤器的作用

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

在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. Servlet到Servlet的请求转发与重定向的区别

    Servlet跳转到另一个Servlet中: request.getRequestDispatcher().forward();代表默认的是post方法,即在被跳转的Servlet的doPost()方 ...

  2. ASP.NET 之 Chart Control for .Net Framework

    ps:曾经靠着这张图做了很多的图形报表

  3. Java系列学习(十)-包与权限修饰符

    1.形式参数和返回值的问题 (1)形式参数: A:类名:需要该类的对象 B:抽象类名:需要改类的子类对象 C:接口名:需要该接口的实现对象 (2)返回值类型: A:类名:抽象类名:返回的是该类的对象 ...

  4. fcc html5 css 练习3

    行内样式看起来是这样的 <h1 style="color: green"> .pink-text { color: pink !important; }         ...

  5. jQuery——入口函数

    中文网 http://www.css88.com/jqapi-1.9/ 版本兼容问题 版本一:1.x版本,兼容IE678 版本二:2.x版本,不兼容IE678 入口函数区别 <script> ...

  6. RTL Compiler之Example

    Synthesis = Translation +  Logic Optimization + Mapping Step 1 Source files 1) make directory mkdir ...

  7. jboss启动问题

    今天一大早客户找我,说他们那边的jboss启动成功了,但是却访问不了. 本以为不是什么事,估计又是客户不会搞,把哪里搞挂了,直接远程把客户的jboss的log.data.tmp等文件给清理了,然后重启 ...

  8. CAD实现自定义实体夹点移动(com接口VB语言)

    主要用到函数说明: MxDrawXCustomEvent::MxDrawXCustomEntity::moveGripPointsAt 自定义实体事件,自定义实体夹点被移动,详细说明如下: 参数 说明 ...

  9. Git学习总结四(删除)

    一般情况下,你通常直接在文件管理器中把没用的文件删了,或者用rm命令删了: $ rm test.txt 这个时候,Git知道你删除了文件,因此,工作区和版本库就不一致了,git status命令会立刻 ...

  10. 阅读《JavaScript设计模式》第二章心得

    面向对象编程 面向对象编程就是将你的需求抽象成一个对象.然后针对这个对象分析其特征(属性)与动作(方法).这个对象我们称之为类.面向对象编程思想其中的一个特点就是封装. 1.私有属性.私有方法.特权方 ...