`

AngularJS过滤器filter

阅读更多

  在开发中,经常会遇到这样的场景:

  如用户的性别分为“男”和“女”,在数据库中保存的值为1和0,用户在查看自己的性别时后端返回的值自然是1或0,前端要转换为“男”或“女”再显示出来;

  如我要换个羽毛球拍,某猫上羽毛球拍的品牌多达数十种,我想单独查看YONEX这个品牌的羽毛球拍;

  买完羽毛球拍我还想买一桶羽毛球,点击按销量排序展示商品;


  以上三种场景分别对数据进行了转换/筛选/排序,总而言之就是对数据的格式化,AngularJS的filter就是用来做这个事的。

 

一.内置过滤器

  AngularJS内置了很多过滤器,在HTML模板的绑定符号{{}}内通过|来调用过滤器,如字母转换成大写:$scope.name='wangmeijian'

{{name | uppercase}}   // 输出 WANGMEIJIAN

  数字转成千分位写法:$scope.num = 12345678

{{num | number}} // 输出 12,345,678

  日期格式化:$scope.date=new Date()

{{date | date:'yy-MM-dd'}}   // 输出 2015-11-19

  数字格式化成货币:$scope.num=987654321

{{num | currency:'¥'}}   // 输出 ¥987,654,321.00

实例如下:

index.html

<html ng-app='app'>
	<head>
		<title>AngularJS过滤器filter入门</title>
	</head>
	<body ng-controller='myController'>
		<p>{{name}}转换成大写:{{name | uppercase}}</p>
		<p>12345678数字转成千分位写法:{{num | number}}</p>
		<p>日期格式化:{{date | date:'yy-MM-dd'}}</p>
		<p>{{987654321| currency:'¥'}}</p>
	</body>
    <script type="text/javascript" src="angular1.2.9.js" ></script>
    <script type="text/javascript" src="filter.js" ></script>
</html>

filter.js

var app = angular.module('app',[])
	.controller('myController',['$scope', function($scope){
		$scope.name = 'abcdefg';
		$scope.num = 12345678;
		$scope.date = new Date();
	}])

运行效果:


  稍微复杂一点的过滤器——‘filter’,可以返回给定数组的子集,它接收一个参数,这个参数可以是字符串、对象、函数。

  字符串:返回所有包含这个字符串的元素,想要返回不包含这个字符串的元素则在前面加!

  demo:

{{['wang','mei','jian'] | filter:'a'}} // 返回包含字母a的元素 ['wang','jian']

  对象:Angular会将待过滤对象的属性与这个对象中的同名属性进行比较,如果属性值是字符串会判断是否包含该字符串(注意这里是包含,并不需要完全相等)

  demo:

{{ [
    {
        name: 'wangmeijian',
        sex: 'boy'
    },
    {
        name: 'bokeyuan',
        sex: 'sex'
    }
   ] | filter:{
        sex: 'bo'
    }
}}

        // 输出 [{"name":"wangmeijian","sex":"boy"}]

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

  demo:

$scope.getNumber = function(n){
  return !isNaN(n);
}
{{ ['demo',2,3] | filter:getNumber}}  // 输出 [2,3]

 

二.自定义过滤器

  当内置函数不能满足你的业务需求时,就需要自定义一个过滤器,自定义过滤器返回一个函数,函数的参数就是HTML模板中|左侧的数据,它会自动传入过滤器中。

  比如需求是将一句话中的每个单词首字母变成大写。

index02.html

<html ng-app='app'>
    <head>
        <title>AngularJS过滤器filter入门</title>
    </head>
    <body ng-controller='myController'>
        <p>{{ str | capitalize}}</p>
        <!-- 输出 Hello, Welcome To Iteye! -->
    </body>
	<script type="text/javascript" src="angular1.2.9.js" ></script>
    <script type="text/javascript" src="index02Filter.js" ></script>
</html>

index02Filter.js

var app = angular.module('app',[])
	.controller('myController',['$scope', function($scope){
		$scope.str = 'hello, welcome to iteye!'
	}])
	.filter('capitalize', function(){
		return function(str){
			var arr = str.split(/\s+/);
			for (var i = 0; i < arr.length; i++) {
				arr[i] = arr[i].substr(0,1).toUpperCase() + arr[i].slice(1);
			};
			return arr.join(" ")
		}
	})

运行效果:

  需要注意的是,内置过滤器‘filter’的参数是函数时,会对数组的每个元素执行该函数,自定义过滤器是对数组对象执行它return的函数。

 

三.实际应用

  在实际应用中,会存在对金额进行取两位小数且做千位分隔符的处理,可以将其做成服务在控制器中调用,也可封装成一个过滤器。如下所示:

index03.html

<html ng-app='app'>
    <head>
        <title>AngularJS过滤器filter入门</title>
    </head>
    <body ng-controller='myController'>
		<p ng-bind='formatNum'></p>
        <p>{{ num | bitSeparatorFilter}}</p>
    </body>
	<script type="text/javascript" src="angular1.2.9.js" ></script>
    <script type="text/javascript" src="index03Filter.js" ></script>
</html>

index03Filter.js

var app = angular.module('app',[])
	.factory('floatUtil', function() {
		return {
			/**
			 * 将浮点数num转换为指定位数places的字符串,位数不够时会四舍五入
			 * */
			toFixed: function (num, places) {
				var times = Math.pow(10, places);
				var des = num * times + 0.5;
				var numStr = (parseInt(des, 10) / times) + '';
				var decimalPlaces = this.getDecimalPlaces(numStr); //小数位数
				if (decimalPlaces > 0) {
					numStr = this.addZero(numStr, places - decimalPlaces);
				} else { //整型
					numStr = this.addZero(numStr + '.', places);
				}
				return numStr;
			},
			/**
			 * 为字符串结尾添加指定个零
			 * */
			addZero: function (numStr, zeroNum) {
				var zeroStr = '';
				zeroNum = zeroNum < 0 ? 0 : zeroNum;
				for (var i = 0; i < zeroNum; i++) {
					zeroStr += '0';
				}
				return numStr + zeroStr;
			},
			/**
			 * 获取小数的位数
			 * */
			getDecimalPlaces: function (num) {
				var numStr = num.toString();
				if (numStr.indexOf('.') > -1) {
					return numStr.split('.')[1].length;
				}
				return 0;
			}
		};
	})
	.factory('baseUtil', function(floatUtil) {
		/**
		 * 千位分隔符
		 * */
		function bitSeparator(num) {
			if (num === 0) {
				return '0.00';
			}
			if (!num) {
				return num;
			}
			var numStr = floatUtil.toFixed(num, 2);
			var decimalStr = '';
			if (numStr.indexOf('.') != -1) {//有小数位
				var numArr = numStr.split('.');
				numStr = numArr[0];
				decimalStr = '.' + numArr[1];
			}
			return numStr.replace(/(\d)(?=(?:\d{3})+$)/g, '$1,') + decimalStr;
		}
		
		return {
			bitSeparator: bitSeparator
		};
	})
	.controller('myController',['$scope', 'baseUtil', function($scope, baseUtil){
		$scope.num = '1352626.32';
		$scope.formatNum = baseUtil.bitSeparator($scope.num);
	}])
	.filter('bitSeparatorFilter', function(baseUtil){
		return function(str){
			return baseUtil.bitSeparator(str);
		};
	})

运行效果:



参考文章:http://www.cnblogs.com/wangmeijian/p/4979452.html

  • 大小: 92.5 KB
  • 大小: 1.2 KB
  • 大小: 7.2 KB
  • 大小: 1.5 KB
分享到:
评论

相关推荐

    AngularJS过滤器filter用法分析

    本文实例讲述了AngularJS过滤器filter用法。分享给大家供大家参考,具体如下: 在开发中,经常会遇到这样的场景 如用户的性别分为“男”和“女”,在数据库中保存的值为1和0,用户在查看自己的性别时后端返回的值...

    AngularJS过滤器filter用法实例分析

    本文实例讲述了AngularJS过滤器filter用法。分享给大家供大家参考,具体如下: 这节我们来看看angularjs的过滤器filter。 在我们开发中经常需要在页面显示给用户的信息需要一定处理格式化,才能显示给用户。比如时间...

    AngularJS过滤器filter用法总结

    本文实例总结了AngularJS过滤器filter用法。分享给大家供大家参考,具体如下: 引言 filter过滤器对于我们来说并不陌生,他和我们现实生活中的过滤器的意思差不多,它的作用就是接收一个输入的值,然后按照某个规则...

    angularjs过滤器--filter与ng-repeat配合有奇效

    本篇文章主要介绍了angularjs过滤器-filter与ng-repeat的相关知识。具有很好的参考价值。下面跟着小编一起来看下吧

    AngularJS 过滤器的简单实例

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

    ykFiltersCapitalize:AngularJS 的大写过滤器

    AngularJS 过滤器将句子和特别是团队名称大写。 分叉和大量修改 安装(尚未发布) 您可以使用安装过滤器: $ bower install yk.filters.capitalize 然后你必须将它包含在你的 HTML 中: &lt; script src =" ...

    AngularJS 过滤器

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

    详解AngularJS中$filter过滤器使用(自定义过滤器)

    主要介绍了详解AngularJS中$filter过滤器使用(自定义过滤器)的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下

    详解AngularJS中的filter过滤器用法

    这篇简单说一下angularjs的filter功能,angularjs的filter功能可分为二种,一种是内置的过滤器,一种是自定义的。 一,内置的过滤器 1,uppercase,lowercase大小转换 {{ "lower cap string" | uppercase }} //结果...

    angular-iso-country-filter:用于将国家_地区的 ISO 缩写转换为其全名的 AngularJS 过滤器

    一个 AngularJS 过滤器,用于将国家/地区的 ISO 缩写转换为其全名。 安装 凉亭安装 angular-iso-country-filter --save 使用示例 注入依赖项: angular . module ( 'app' , [ 'isoCountryFilter' ] ) 并使用...

    AngularJS中的过滤器filter用法完全解析

    在AngularJS的世界里,filter提供了一种格式化数据的方法,Angular也提供给我们了很多内建的过滤器,并且建立自定义过滤器也是相当的简单 在HTML的模板绑定{{}}中,我们使用 | 来调用过滤器,比如,我们想让字符串...

    angular-zipcode-filter:AngularJS过滤器可自动设置长邮政编码和短邮政编码的格式

    AngularJS过滤器可自动设置长邮政编码和短邮政编码的格式。 安装 您可以使用安装过滤器: $ bower install angular-zipcode-filter 或 : $ npm install angular-zipcode-filter 然后,您必须将其包含在HTML中:...

    详解Angularjs filter过滤器

    这篇简单说一下angularjs的filter功能,angularjs的filter功能可分为二种,一种是内置的过滤器,一种是自定义的。 Filter是用来格式化数据用的。 Filter的基本原型( ” 类似于Linux中的管道模式): {{ expression...

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

    AngularJS有很多实用的内置过滤器,同时也提 供了方便的途径可以自己创建过滤器。 在HTML中的模板绑定符号{{ }}内通过|符号来调用过滤器。例如:{{value|lowercase}}//将值转换成小写 在JavaScript代码中可以通过$...

    详解AngularJS过滤器的使用

    AnularJS的过滤器用来格式化...在JavaScript代码中可以通过$filter来调用过滤器。例如,在JavaScript代码中使用lowercase 过滤器: app.controller('DemoController', ['$scope', '$filter', function($scope, $filte

Global site tag (gtag.js) - Google Analytics