实例解析angularjs的filter过滤器


Posted in Javascript onDecember 14, 2016

现在公司用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>

效果展示:

按年龄排序(默认升序)
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>

效果展示:

按年龄排序(加参数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>

效果展示:

想先按年龄升序在按身高降序(全是降序了,达不到效果,见第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>

效果展示:

先按年龄在按身高排序(多个参数写出数组形式)
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>

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
javascript编程起步(第五课)
Feb 27 Javascript
jQuery获取浏览器中的分辨率实现代码
Apr 23 Javascript
JavaScript中的eval()函数使用介绍
Dec 31 Javascript
Javascript的表单验证长度
Mar 16 Javascript
jQuery判断元素是否显示 是否隐藏的简单实现代码
May 19 Javascript
vue-resource 拦截器使用详解
Feb 21 Javascript
Javascript中 toFixed四舍六入方法
Aug 21 Javascript
jquery引入外部CDN 加载失败则引入本地jq库
May 23 jQuery
vue+axios 前端实现的常用拦截的代码示例
Aug 23 Javascript
又拍云 Node.js 实现文件上传、删除功能
Oct 28 Javascript
vue请求服务器数据后绑定不上的解决方法
Oct 30 Javascript
原生js拖拽实现图形伸缩效果
Feb 10 Javascript
微信小程序 input输入框控件详解及实例(多种示例)
Dec 14 #Javascript
javascript中对象的定义、使用以及对象和原型链操作小结
Dec 14 #Javascript
JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)
Dec 14 #Javascript
javascript中的try catch异常捕获机制用法分析
Dec 14 #Javascript
微信小程序 scroll-view组件实现列表页实例代码
Dec 14 #Javascript
AngularJS指令中的绑定策略实例分析
Dec 14 #Javascript
JavaScript触发onScroll事件的函数节流详解
Dec 14 #Javascript
You might like
用PHP+java实现自动新闻滚动窗口
2006/10/09 PHP
PHP目录函数实现创建、读取目录教程实例
2011/01/13 PHP
PHP MPDF中文乱码的解决方式
2015/12/08 PHP
php PDO实现的事务回滚示例
2017/03/23 PHP
PHP实现二维数组(或多维数组)转换成一维数组的常见方法总结
2019/12/04 PHP
070823更新的一个[消息提示框]组件 兼容ie7
2007/08/29 Javascript
使用focus方法让光标默认停留在INPUT框
2014/07/29 Javascript
js实现跨域的多种方法
2015/12/25 Javascript
由简入繁实现Jquery树状结构的方法(推荐)
2016/06/10 Javascript
跨域请求的完美解决方法(JSONP, CORS)
2016/06/12 Javascript
微信小程序 Canvas增强组件实例详解及源码分享
2017/01/04 Javascript
JS中Select下拉列表类(支持输入模糊查询)功能
2017/01/17 Javascript
Bootstrap导航条学习使用(一)
2017/02/08 Javascript
JS实现复制功能
2017/03/01 Javascript
浅析vue component 组件使用
2017/03/06 Javascript
JavaScript如何一次性展示几万条数据
2017/03/30 Javascript
新手快速上手webpack4打包工具的使用详解
2019/01/28 Javascript
p5.js临摹动态图形实现方法详解
2019/10/23 Javascript
解决基于 keep-alive 的后台多级路由缓存问题
2020/12/23 Javascript
[56:42]VP vs RNG 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/17 DOTA
Python3实现将文件树中所有文件和子目录归档到tar压缩文件的方法
2015/05/22 Python
python调用百度语音REST API
2018/08/30 Python
python 使用sys.stdin和fileinput读入标准输入的方法
2018/10/17 Python
Pandas Shift函数的基础入门学习笔记
2018/11/16 Python
搞定这套Python爬虫面试题(面试会so easy)
2019/04/03 Python
Python日志无延迟实时写入的示例
2019/07/11 Python
解决jupyter notebook 出现In[*]的问题
2020/04/13 Python
使用darknet框架的imagenet数据分类预训练操作
2020/07/07 Python
如何基于pandas读取csv后合并两个股票
2020/09/25 Python
StudentUniverse英国:学生航班、酒店和旅游
2019/08/25 全球购物
畜牧兽医本科生的自我评价
2014/03/03 职场文书
行政人事岗位职责
2014/03/17 职场文书
温馨提示标语
2014/06/26 职场文书
高三数学复习备考教学反思
2016/02/18 职场文书
解决Vue+SpringBoot+Shiro跨域问题
2021/06/09 Vue.js
python实现简单的聊天小程序
2021/07/07 Python