AngularJS 过滤器(自带和自建)详解


Posted in Javascript onSeptember 19, 2016

过滤器用来格式化需要展示给用户的数据。AngularJS有很多实用的内置过滤器,同时也提
供了方便的途径可以自己创建过滤器。

在HTML中的模板绑定符号{{ }}内通过|符号来调用过滤器。例如:{{value|lowercase}}//将值转换成小写

在JavaScript代码中可以通过$filter来调用过滤器

例:

 app.controller(‘DemoController‘, [‘$scope‘, ‘$filter‘,
function($scope, $filter) {

$scope.name = $filter(‘lowercase‘)(‘Ruby‘);

}]);

以HTML的形式使用过滤器时,如果需要传递参数给过滤器,只要在过滤器名字后面加冒号
即可。如果有多个参数,可以在每个参数后面都加入冒号。

例如

{{0.23145|number:3}}

显示值:0.231//数值过滤器 可以限制小数点后的位数(在过滤器后写上2,将2作为参数传递给过滤器)

可以用|符号作为分割符来同时使用多个过滤器

一:下面介绍AngularJS提供的内置过滤器:

 1.currecy过滤器可以将一个数值格式化为货币格式。用{{ 50| currency }}来将50转化成货币格式。
currecy过滤器允许我们自己设置货币符号。默认情况下会采用客户端所处区域的货币符号,
但是也可以自定义货币符号。

2.date过滤器可以将日期格式化成需要的格式。AngularJS中内置了几种日期格式,如果没有

指定使用任何格式,默认会采用mediumDate格式

下面是内置的支持本地化的日期格式:

{{ today | date:‘medium‘ }} <!-- Aug 09, 2013 12:09:02 PM -->
{{ today | date:‘short‘ }} <!-- 8/9/1312:09PM -->
{{ today | date:‘fullDate‘ }} <!-- Thursday, August 09, 2013 -->
{{ today | date:‘longDate‘ }} <!-- August 09, 2013 -->
{{ today | date:‘mediumDate‘ }}<!-- Aug 09, 2013 -->
{{ today | date:‘shortDate‘ }} <!-- 8/9/13 -->
{{ today | date:‘mediumTime‘ }}<!-- 12:09:02 PM -->
{{ today | date:‘shortTime‘ }} <!-- 12:09 PM -->

 年份格式化

四位年份:{{ today | date:‘yyyy‘ }} <!-- 2013 -->
两位年份:{{ today | date:‘yy‘ }} <!-- 13 -->
一位年份:{{ today | date:‘y‘ }} <!-- 2013 -->

月份格式化

英文月份:{{ today | date:‘MMMM‘ }} <!-- August -->
英文月份简写:{{ today | date:‘MMM‘ }} <!-- Aug -->
数字月份:{{ today |date:‘MM‘ }} <!-- 08 -->
一年中的第几个月份:{{ today |date:‘M‘ }} <!-- 8 -->

日期格式化

数字日期:{{ today|date:‘dd‘ }} <!-- 09 -->

一个月中的第几天:{{ today | date:‘d‘ }} <!-- 9 -->

英文星期:{{ today | date:‘EEEE‘ }} <!-- Thursday -->
英文星期简写:{{ today | date:‘EEE‘ }} <!-- Thu -->

小时格式化

24小时制数字小时:{{today|date:‘HH‘}} <!--00-->
一天中的第几个小时:{{today|date:‘H‘}} <!--0-->
12小时制数字小时:{{today|date:‘hh‘}} <!--12-->
上午或下午的第几个小时:{{today|date:‘h‘}} <!--12-->

分钟格式化

数字分钟数:{{ today | date:‘mm‘ }} <!-- 09 -->
一个小时中的第几分钟:{{ today | date:‘m‘ }} <!-- 9 -->

秒数格式化

数字秒数:{{ today | date:‘ss‘ }} <!-- 02 -->
一分钟内的第几秒:{{ today | date:‘s‘ }} <!-- 2 -->
毫秒数:{{ today | date:‘.sss‘ }} <!-- .995 -->

字符格式化

上下午标识:{{ today | date:‘a‘ }} <!-- AM -->
四位时区标识:{{ today | date:‘Z‘ }} <!--- 0700 -->

自定义日期格式示例:

{{ today | date:‘MMMd, y‘ }} <!-- Aug9, 2013 -->
{{ today | date:‘EEEE, d, M‘ }} <!-- Thursday, 9, 8-->
{{ today | date:‘hh:mm:ss.sss‘ }} <!-- 12:09:02.995 -->

3.filter

  filter过滤器可以从给定数组中选择一个子集,并将其生成一个新数组返回。这个过滤器通常用来过滤需要进行展示的元素。

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

 1)传入的参数是字符串时

    返回所有包含这个字符串的元素。如果我们想返回不包含该字符串的元素,在参数前加!符号。

   例:

      {{ [‘Bri‘,‘Lerner‘,‘Likes‘,‘To‘,‘Eat‘,‘Pizza‘] | filter:‘e‘ }}

<!-- ["Lerner","Likes","Eat"] -->

2)传入的参数是对象

   AngularJS会将待过滤对象的属性同这个对象中的同名属性进行比较,如果属性值是字符串就会判断是否包含该字符串。如果我们希望对全部属性都进行对比,可以将$当作键名。

例:

 {{ [{


‘name‘: ‘Ari‘,



‘City‘: ‘San Francisco‘,



‘favorite food‘: ‘Pizza‘


},{



‘name‘: ‘Nate‘,



‘City‘: ‘San Francisco‘,



‘favorite food‘: ‘indian food‘

}] | filter:{‘favorite food‘: ‘Pizza‘} }}
<!-- [{"name":"Ari","City":"SanFrancisco","favoritefood":"Pizza"}] -->

3)函数

   对每个元素都执行这个函数,返回非假值的元素会出现在新的数组中并返回。

  自定义函数进行过滤(在这个例子中函数定义在$scope上):

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

 <!-- ["Ari"] -->
 isCapitalized函数的功能是根据首字母是否为大写返回true或false,具体如下所示:
 $scope.isCapitalized = function(str) {
 return str[0] == str[0].toUpperCase();
 };

4.json

json过滤器可以将一个JSON或JavaScript对象转换成字符串。这种转换对调试非常有帮助:
{{ {‘name‘: ‘Ari‘, ‘City‘: ‘SanFrancisco‘} | json }}

<!--


{



"name": "Ari",



"City": "San Francisco"


}

-->

5.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"] -->

6 lowercase

  lowercase过滤器将字符串转为小写。

7.number

  number过滤器将数字格式化成文本。它的第二个参数是可选的,用来控制小数点后截取的位数。(如果传入了一个非数字字符,会返会空字符串。)

8.orderBy

  orderBy过滤器可以用表达式对指定的数组进行排序。

  orderBy可以接受两个参数,第一个是必需的,第二个是可选的。

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

 下面分情况讨论第一个参数的类型。

函数

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

字符串

对这个字符串进行解析的结果将决定数组元素的排序方向。我们可以传入+或-来强制进行升序或降序排列。

数组

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

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

  例:

 {{ [{


‘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可以将排序结果进行反转:orderBy:‘name‘:true)

9.uppercase

 uppercase过滤器可以将字符串转换为大写形式:

 二:自定义过滤器

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

下面举例说明:

 将name以首字母大写形式显示

<!DOCTYPE html>
<html>
<head>
 <title>Custom Filter</title>
 <meta charset="utf-8" />
 <script type="text/javascript" src="angular.min.js"></script>
</head>
<body ng-app="customFilter" ng-controller="filterController">
 <h1>{{name|lowercase|Capitalize}}</h1>
 <script type="text/javascript" src="customfilter.js"></script>
</body>
</html>

customfilter.js

(function () {
 var app = angular.module(‘customFilter‘, []);
 app.controller(‘filterController‘, function ($scope) {
  $scope.name = ‘JACK‘;
 });
 app.filter(‘Capitalize‘, function () {
  return function (input) {
   if (input) {
    return input[0].toUpperCase() + input.slice(1);
   }
  };
 });
})();

以上就是对AngularJS 过滤器 的资料整理,后续继续补充相关资料,谢谢大家对本站的支持!

Javascript 相关文章推荐
Javascript 跨域访问解决方案
Feb 14 Javascript
Extjs中TabPane如何嵌套在其他网页中实现思路及代码
Jan 27 Javascript
兼容各大浏览器的JavaScript阻止事件冒泡代码
Jul 09 Javascript
基于jQuery仿淘宝产品图片放大镜代码分享
Jun 23 Javascript
Jquery跨浏览器文本复制插件Zero Clipboard的使用方法
Feb 28 Javascript
Ajax验证用户名或昵称是否已被注册
Apr 05 Javascript
Vue.Draggable实现拖拽效果
Jul 29 Javascript
详解原生JS回到顶部
Mar 25 Javascript
详解a标签添加onclick事件的几种方式
Mar 29 Javascript
webpack的tree shaking的实现方法
Sep 18 Javascript
vue实现文字加密功能
Sep 27 Javascript
vue props default Array或是Object的正确写法说明
Jul 30 Javascript
js Canvas实现圆形时钟教程
Sep 19 #Javascript
Bootstrap模态框调用功能实现方法
Sep 19 #Javascript
javascript实现的上下无缝滚动效果
Sep 19 #Javascript
Angular ng-class详解及实例代码
Sep 19 #Javascript
javascript实现的左右无缝滚动效果
Sep 19 #Javascript
javascript实现图片左右滚动效果【可自动滚动,有左右按钮】
Sep 19 #Javascript
BootStrap入门教程(三)之响应式原理
Sep 19 #Javascript
You might like
PHP 判断常量,变量和函数是否存在
2009/04/26 PHP
PHP基于mssql扩展远程连接MSSQL的简单实现方法
2016/10/08 PHP
使用jquery给input和textarea设定ie中的focus
2008/05/29 Javascript
增强用户体验友好性之jquery easyui window 窗口关闭时的提示
2012/06/22 Javascript
jQuery实现简单网页遮罩层/弹出层效果兼容IE6、IE7
2014/06/16 Javascript
JavaScript实现页面5秒后自动跳转的方法
2015/04/16 Javascript
JS实现网页上随机产生超链接地址的方法
2015/11/09 Javascript
[原创]JQuery 在表单提交之前修改 提交的值
2016/04/14 Javascript
jquery显示隐藏元素的实现代码
2016/05/19 Javascript
JavaScript必知必会(六) delete in instanceof
2016/06/08 Javascript
js select实现省市区联动选择
2020/04/17 Javascript
Js动态设置rem来实现移动端字体的自适应代码
2016/10/14 Javascript
BootStrap入门学习第一篇
2017/08/28 Javascript
浅谈AngularJS中使用$resource(已更新)
2017/09/14 Javascript
webpack 插件html-webpack-plugin的具体使用
2018/04/09 Javascript
vue mounted组件的使用
2018/06/18 Javascript
php结合js实现多条件组合查询
2019/05/28 Javascript
微信小程序绑定手机号获取验证码功能
2019/10/22 Javascript
Node.js学习之内置模块fs用法示例
2020/01/22 Javascript
从零学python系列之新版本导入httplib模块报ImportError解决方案
2014/05/23 Python
跟老齐学Python之开始真正编程
2014/09/12 Python
Windows系统下安装Python的SSH模块教程
2015/02/05 Python
Python将阿拉伯数字转换为罗马数字的方法
2015/07/10 Python
Python内置函数——__import__ 的使用方法
2017/11/24 Python
python模拟菜刀反弹shell绕过限制【推荐】
2019/06/25 Python
Python全栈之列表数据类型详解
2019/10/01 Python
Python flask路由间传递变量实例详解
2020/06/03 Python
GIVENCHY纪梵希官方旗舰店:高定彩妆与贵族护肤品
2018/04/16 全球购物
打架检讨书400字
2014/01/17 职场文书
新三好学生主要事迹
2014/01/23 职场文书
新任教师自我鉴定
2014/02/24 职场文书
《白鹅》教学反思
2014/04/13 职场文书
初中家长评语和期望
2014/12/26 职场文书
基于Redis实现分布式锁的方法(lua脚本版)
2021/05/12 Redis
mysql连接查询中and与where的区别浅析
2021/07/01 MySQL
Python使用socket去实现TCP客户端和TCP服务端
2022/04/12 Python